80188 


High Integration 8-Bit Microprocessor 
iAPX86 Family 


DISTINCTIVE CHARACTERISTICS 


@ Integrated feature set @ High-performance processor 
- Enhanced 10 MHz 8088-1 CPU - Two times the performance of the standard 8088 
- Clock generator - 2.25 Mbyte/sec bus bandwidth interface 
- Two independent, high-speed DMA channels Direct addressing capability to 1 Mbyte of memory 
- Programmable interrupt controller Completely object code compatible with all existing 
- Three programmable 16-bit timers iAPX 86, 88 software 
- Programmable memory and peripheral chip-select - Ten new instruction types 
logic - Compatible with 29843/45, 29833/63, 8284, and 
- Programmable wait state generator 8288 bus support components 
— Local bus controller Optional numeric processor extension 
@ Eight-bit data bus interface, 16-bit internal architecture Available in 68-pin Plastic Leaded Chip Carrier (PLCC), 
@ Available in 10 MHz (80188-10), 8 MHz (80188) Ceramic Leadless Chip Carrier (LCC), and Pin Grid Array 
(PGA) packages. 


GENERAL DESCRIPTION 


The 80188 is a highly-integrated microprocessor with an the standard 5 MHz 8088. The 80188 is upward compatible 
8-bit data bus interface and a 16-bit internal architecture for with 8086 and 8088 software and adds 10 new instruction 
high performance. It effectively combines 15-20 of the most types to the existing set. 

common iAPX 86 system components onto one. The 


8 MHz 80188 provides two times greater throughput than The80188 comes in a G2-pin package and requires.2.single 


+5 V power supply. 
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CONNECTION DIAGRAMS 
Leadless Chip Carrier (LCC*) 
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*LCC package placed in socket top down. 


Pin Grid Array (PGA) 


Pins Facing Up Pins Facing Down 
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Plastic Leaded Chip Carrier (PLCC**) 


CD010530 


**PLCC package placed in socket top up. 





LOGIC SYMBOL 


Aie/S3-Ayp/S8 


~ LS001970 
ORDERING INFORMATION 
Commodity Products 
AMD commodity products are available in several packages and operating ranges. The order number (Valid Combination) 
is formed by a combination of: a. Temperature Range 
b. Package Type 
3 c. Device Number 
d. Speed Option 
e. Optional Processing 
aces 
B Valid Combinations 
ARN 80188 
e. OPTIONAL PROCESSING 80188-10 
B = Burn-in A, A, IA, IR 80188B 
d. SPEED OPTION 
bast ary Valid Combinations 
Sean . Valid combinations list configurations 
c. DEVICE NUMBER/DESCRIPTION planned to be supported in volume for 
80188 ; we this device. Consult the local AMD sales 
ie High Integration 8-Bit Microprocessor office to confirm availability of specific 
SS b. PACKAGE TYPE ee ae mrise to check on newly 
R = 68-Pin Ceramic Leadless Chip Carrier (CA2068) released valid combinations, and to 


N = 68-Pin Plastic Leaded Chip Carrier (PL 068) obtain additional data on AMD's standard 
A=68-Pin Grid Array (CGX068) military grade products. 


a. TEMPERATURE RANGE 
Blank = Commercial (0 to + 70°C) 
| = Industrial (-40 to + 85°C) 















PIN DESCRIPTION 


active state | Name | vo | Desorption 


| sd Vea, Voc | |__| System Power: +5 volt power supply. 
| =i ss. Vs | _! __| System Ground. 


Active HIGH RESET Reset Output indicates that the 80188 CPU is being reset; and can be used as a system reset. It is 
active HIGH, synchronized with the processor clock, and lasts an integer number of clock periods 
corresponding to the length of the RES signal. 
will resume. If interrupts are enabled while the 80188 is waiting for TEST, interrupts will be serviced. 
interrupt requests must remain active until the interrupt is acknowledged. When iRMX mode is selected, 
cycle, effectively one-half clock cycle earlier than in the standard 8088. The trailing edge is generated 


Crystal inputs, X1 and X2, provide an external connection for a fundamental mode parallel resonant 
- | 4 

This input is synchronized internally. 

the function of these pins changes (see Interrupt Controller section of this data sheet). 

off the CLKOUT rising edge in T; as in the 8088. Note that ALE is never floated. 
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Active HIGH 


crystal for the internal crystal oscillator. X1 can interface to an external clock instead of a crystal. The 
input or oscillator frequency is internally divided by two to generate the clock signal (CLKOUT). 
Clock Output provides the system with a 50% duty cycle waveform. All device pin timings are specified 
relative to CLKOUT. CLKOUT has sufficient MOS drive capabilities for a numeric processor extension. 
System Reset causes the 80188 to immediately terminate its present activity, clear the internal logic, 
and enter a dormant state. This signal may be asynchronous to the 80188 clock. The 80188 begins 
fetching instructions approximately 7 clock cycles after RES is returned HIGH. RES is required to be 
LOW for greater than 4 clock cycles and is internally synchronized. For proper initialization, the LOW-to- 
HIGH transition of RES must occur no sooner than 50 microseconds after power up. This input is 
provided with a Schmitt-trigger to facilitate power-on RES generation via an RC network. When RES 
occurs, the 80188 will drive the status lines to an inactive level for one clock, and then tri-state them. 
Active LOW TEST TEST is examined by the WAIT instruction. If the TEST input is HIGH when "WAIT" execution begins, 
instruction execution will suspend. TEST will be resampled until it goes LOW, at which time execution 
Active HIGH TMR in 0, Timer inputs are used either as clock or control signals, depending upon the programmed timer mode. 
TMR IN1 These inputs are active HIGH (or LOW-to-HIGH transitions are counted) and internally synchronized. 
Active HIGH TMR OUT 0, Timer outputs are used to provide single pulse or continuous waveform generation, depending upon the 
TMR OUT 1 timer mode selected. 
Active HIGH DRQO DMA Request is driven HIGH by an external device when it desires that a DMA channel (Channel 0 or 1) 
DRQ1 perform a transfer. These signals are active HIGH, level-triggered, and internally synchronized. 
Active HIGH Non-Maskable Interrupt is an edge-triggered input which causes a type 2 interrupt. NMI is not maskable 
internally. A transition from a LOW to HIGH initiates the interrupt at the next instruction boundary. NMI is 
latched internally. An NMI duration of one clock or more will guarantee service. This input is internally 
synchronized. 
Active HIGH INTO, INT1 Maskable Interrupt Requests can be requested by strobing one of these pins. When configured as 
or INT2/INTAO inputs, these pins are active HIGH. Interrupt Requests are synchronized internally. INT2 and INT3 may 
LOW INT3/INTA1 be configured via software to provide active-LOW interrupt-acknowledge output signals. All interrupt 
inputs may be configured via software to be either edge- or level-triggereed. To ensure recognition, all 
Address Bus Outputs (16-19) and Bus Cycle Status (3-6) reflect the four most significant address bits 
during T;. These signals are active HIGH. During To, T3, Tw, and Ty, status information is available on 
these lines as encoded below: 
Low | High 
DMA Cycle 
$3, S4, and S5 are defined as LOW during To-T4. 
Address/Data Bus (0-7) signals constitute the time multiplexed memory or I/O address (T1) and data 
(To, T3, Tw, and T4) bus. 
Address-only Bus (8-15), containing valid address from T4-T4. 
This signal is always HIGH to indicate that the 80188 has an 8-bit data bus and is tri-state OFF during 
bus hold. 
Address Latch Enable/Queue Status 0 is provided by the 80188 to latch the address into the 8282/ 
8283 address latches. Addresses are guaranteed to be valid on the trailing edge of ALE. The ALE rising 
edge is generated off the rising edge of the CLKOUT immediately preceding T; of the associated bus 


A19/S6, 
A18/S5, 
A17/S4, 
A16/S3 





Active HIGH AD7-ADO V0 


Active HIGH A15-A8 


Active HIGH ALE/QSO 
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PIN DESCRIPTION (Cont.) 


Active State | Name =| vo | Description 
Active LOW WR/QS1 Write Strobe/Queue Status 1 indicates that the data on the bus is to be written into a memory or an I/O 
device. WR is active for T2, T3, and Tw of any write cycle. Floats during "HOLD." It is driven HIGH for 
one clock during Reset, and then floated. When the 80188 is in queue status mode, the ALE/QSO and 
WR/QS1 pins provide information about processor/instruction queue interaction. 
|__ asi |__aso_ Queue Operation 
[oo (Re quate operation SC*d 
| 0 | 4 | First opcode byte fetched from the queue 
ay ee ee ee 


Subsequent byte fetched from the queue 
Active LOW RD/QSMD 
CK 























floated. RD is active LOW, and floats during ''HOLD." RD is driven HIGH for one clock during Reset, 
and then the output driver is floated. A weak internal pull-up mechanism on the RD line holds it HIGH 
when the line is not driven. During RESET the pin is sampled to determine whether the 80188 should 
provide ALE, WR, and RD, or if the Queue-Status should be provided. RD should be connected to GND 
to provide Queue-Status data. 


Asynchronous Ready informs the 80188 that the addressed memory space or I/O device will complete 
a data transfer. The ARDY input pin will accept an asynchronous input, and is active HIGH. Only the 
rising edge is internally synchronized by the 80188. This means that the falling edge of ARDY must be 
synchronized to the 80188 clock. If connected to Vcc, no WAIT states are inserted. Asynchronous 
ready (ARDY) or synchronous ready (SRDY) /ust be active to terminate a bus cycle. If line is unused, it 
may remain connected to Vcc or it may be connected to Vsg (in which case the programmer must 
initialize the part to inhibit the external pins). 


Synchronous Ready must be synchronized externally to the 80188. The use of SRDY provides a 
relaxed system-timing specification on the Ready input. This is accomplished by eliminating the one-half 
clock cycle which is required for internally resolving the signal level when using the ARDY input. This 
line is active HIGH. If this line is connected to Vcc no WAIT states are inserted. Asynchronous ready 
(ARDY) or synchronous ready (SRDY) must be active before a bus cycle is terminated. If line is unused, 
it may remain connected to Vcc or it may be connected to Vgsg (in which case the programmer must 
initialize the part to inhibit the external pins). 


LOCK output indicates that other system bus masters are not to gain control of the system bus while 
LOCK is active LOW. The LOCK signal is requested by the LOCK prefix instruction and is activated at 
the beginning of the first data cycle associated with the instruction following the LOCK prefix. It remains 
active until the completion of the instruction following the LOCK prefix. No prefetches will occur while 
LOCK is asserted. When executing more than one LOCK instruction, there must be six bytes of code 
between the end of the first LOCK instruction and the start of the second LOCK instruction. LOCK is 
active LOW, is driven HIGH for one clock during RESET, and then floated. 


Bus cycle status S0-S2 are encoded to provide bus-transaction information: 
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Empty the queue 
Read Strobe indicates that the 80188 is performing a memory or I/O read cycle. RD is active LOW for 
Ta, Tg, and Tw of any read cycle. It is guaranteed not to go LOW in T2 until after the Address Bus is 
Active HIGH ARDY 
Active HIGH SRDY 
a robs 







































































The status pins float during "HOLD." 


S2 may be used as a logical M/IO indicator, and S1 as a DT/R indicator. 
The status lines are driven HIGH for one clock during Reset, and then floated until a bus cycle begins. 


HOLD indicates that another bus master is requesting the local bus. The HOLD input is active HIGH. 
HOLD may be asynchronous with respect to the 80188 clock. The 80188 will issue a HLDA in response 
to a HOLD request at the end of T4 or Ty Simultaneous with the issuance of HLDA, the 80188 will float 
the local bus and control lines. After HOLD is detected as being LOW, the 80188 will lower HLDA. When 
the 80188 needs to run another bus cycle, it will again drive the local bus and control lines. 


Upper Memory Chip Select is an active LOW output whenever a memory reference is made to the 
defined upper portion (1K-=256K block) of memory. This line is not floated during bus HOLD. The 
address range activating UCS is software programmable. 


Lower Memory Chip Select is active LOW whenever a memory reference is made to the defined lower 
portion (1K-256K) of memory. This line is not floated during bus HOLD. The address range activating 
LCS is software programmable. 


Mid-Range Memory Chip Select signals are active LOW when a memory reference is made to the 
defined mid-range portion of memory (8K-512K). These lines are not floated during bus HOLD. The 
address ranges activating MCSO-3 are software programmable. 


Peripheral Chip Select signals 0-4 are active LOW when a reference is made to the defined peripheral 
area (65K byte I/O space). These lines are not floated during bus HOLD. The address ranges activating 
PCS0-4 are software programmable. 

































HOLD (input) 
HLDA (output) 






























PIN DESCRIPTION (Cont.) 


Description 


Peripheral Chip Select 5 or Latched A1 may be programmed to provide a sixth peripheral chip select, or 
to provide an internally latched A1 signal. The address range activating PCS5 is software 
programmable. When programmed to provide latched A1, rather than PCSS, this pin will retain the 
previously latched value of A1 during a bus HOLD. 


Peripheral Chip Select 6 or Latched A2 may be programmed to provide a seventh peripheral chip select, 

or or to provide an internally latched A2 signal. The address range activating PCS6 is software 
HIGH programmable. When programmed to provide latched A2, rather than PCS6, this pin will retain the 
previously latched value of A2 during a bus HOLD. 


Data Transmit/Receive controls the direction of data flow through the external 2946/47 data bus 
transceiver. When LOW, data is transferred to the 80188. When HIGH the 80188 places write data on 
the data bus. 


Data Enable is provided as a 2946/47 data bus transceiver output enable. DEN is active LOW during 


Active LOW 


each memory and I/O access. DEN is HIGH whenever DT/R changes state. 


FUNCTIONAL DESCRIPTION 


Introduction 


The following Functional Description describes the base archi- 
tecture of the 80188. The architecture is common to the 8086, 
8088, and 80286 microprocessor families as well. The 80188 is 
a very high integration 8-bit microprocessor. It combines 15-20 
of the most common microprocessor system components onto 
one chip while providing twice the performance of the standard 
8088. The 80188 is object code compatible with the 8086, 
8088 microprocessors and adds 10 new instruction types to the 
existing 8086, 8088 instruction set. 


80188 BASE ARCHITECTURE 


The 8086, 8088, 80188, 80186 and 80286 family all contain 
the same basic set of registers, instructions, and addressing 
modes. The 80188 processor is upward compatible with the 
8086, 8088, 80186 and 80286 CPUs. 


Register Set 


The 80188 base architecture has fourteen registers as shown 
in Figures 1 and 2. These registers are grouped into the 
following categories. 


General Registers 


Eight 16-bit general purpose registers used to contain arithme- 
tic and logical operands. Four of these (AX, BX, CX, and DX) 
can be used as 16-bit registers or split into pairs of separate 
8-bit registers. 


16-B1T SPECIAL 
REGISTER REGISTER 
NAME FUNCTIONS 


BYTE 
ADDRESSABLE 
(8-BIT 
REGISTER 


MULTIPLY/OIVIDE 
1/0 INSTRUCTIONS 


NAMES LOOP/SHIFT/REPEAT/COUNT 


SHOWN) 


BASE REGISTERS 


INDEX REGISTERS 


STACK POINTER 


GENERAL 
REGISTERS 


Segment Registers 


Four 16-bit special purpose registers select, at any given time, 
the segments of memory that are immediately addressable for 
code, stack, and data. (For usage, refer to Memory Organiza- 
tion.) 


Base and Index Registers 


Four of the general purpose registers may also be used to 
determine offset addresses of operands in memory. These 
registers may contain base addresses or indexes to particular 
locations within a segment. The addressing mode selects the 
specific registers for operand and address calculations. 


Status and Control Registers 


Two 16-bit special purpose registers record or alter certain 
aspects of the 80188 processor state. These are the Instruc- 
tion Pointer Register, which contains the offset address of the 
next sequential instruction to be executed, and the Status 
Word Register, which contains status and control flag bits (see 
Figures 1 and 2). 


Status Word Description 


The Status Word records specific characteristics of the result 
of logical and arithmetic instructions (bits 0, 2, 4, 6, 7, and 11) 
and controls the operation of the 80188 within a given 
operating mode (bits 8, 9, and 10). The Status Word Register 
is 16-bits wide. The function of the Status Word bits is shown 
in Table 2. 


CODE SEGMENT SELECTOR 

DATA SEGMENT SELECTOR 

STACK SEGMENT SELECTOR 

EXTRA SEGMENT SELECTOR 
SEGMENT REGISTERS 
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STATUS WORD 


INSTRUCTION POINTER 


STATUS AND CONTROL 
REGISTERS 
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Figure 1. 80188 General Purpose Register Set 





STATUS FLAGS: 
CARRY 

PARITY 

AUXILIARY CARRY 
ZERO 

SIGN 
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RESERVED 


CONTROL FLAGS: 
TRAP FLAG 
INTERRUPT ENABLE 
DIRECTION FLAG 


DF002910 


Figure 2. Status Word Format 


Table 2. Status Word Bit Function 


Bit 
Position 


Carry Flag — Set on high-order bit carry 
or borrow; cleared otherwise. 


Parity Flag — Set if low-order 8 bits or 
result contain an even number of 1-bits; 
cleared otherwise. 


Zero Flag — Set if result is zero; cleared 
otherwise. 


Sign Flag — Set equal to high-order bit 
of result (0 if positive, 1 if negative). 


Single Step Flag— Once set, a single 
step interrupt occurs after the next in- 
struction executes. TF is cleared by the 
single step interrupt. 


Interrupt-enable Flag— When set, 
maskable interrupts will cause the CPU 
to transfer control to an interrupt vector 
specified location. 


Direction Flag — Causes string instruc- 
tions to auto decrement the appropriate 
index register when set. Clearing DF 
causes auto increment. 


Overflow Flag — Set if the signed result 
cannot be expressed within the number 
of bits in the destination operand; 
cleared otherwise. 


Instruction Set 


The instruction set is divided into seven categories: data 
transfer, arithmetic, shift/rotate/logical, string manipulation, 
control transfer, high-level instructions, and processor control. 
These categories are summarized in Figure 3. 


An 80188 instruction can reference anywhere from zero to 
several operands. An operand can reside in a register, in the 
instruction itself, or in memory. Specific operand addressing 
modes are discussed later in this data sheet. 


Memory Organization 


Memory is organized in sets of segments. Ban B Segment isa 
linear contiguous sequence of up to 64K (2! 8) 8-bit bytes. 
Memory is addressed using a two-component address (a 
pointer) that consists of a 16-bit base segment and a 16-bit 
offset. The 16-bit base values are contained i one of four 
internal segment registers (code, data, stack, extra). The 
physical address is calculated by shifting the base value LEFT 
by four bits and adding the 16-bit offset value to yield a 20-bit 
physical address (see Figure 4). This allows for a 1 MByte 
physical address size. 


All instructions that address operands in memory must specifiy 
the base segment and the 16-bit offset value. For speed and 
compact instruction encoding, the segment register used for 
physical address generation is implied by the addressing 
mode used (see Table 3). These rules follow the way 
programs are written (see Figure 5) as independent modules 
that require areas for code and data, a stack, and access to 
external data areas. 


Special segment override instruction prefixes allow the implicit 
segment register selection rules to be overridden for special 
cases. The stack, data, and extra segments may coincide for 
simple programs. 





GENERAL PURPOSE 
MOV Move byte or word 
PUSH Push word onto stack 


Pop word off stack 


Push all registers on stack 


PUSHA i 


OUT Output byte or word 
LES 
POPE 


ADDITION 
D Add byte or word 
C Add byte or word with carry 
Cc Increment byte or word by 1 
AA 


AD! 
AD! 
IN 


ASCII adjust for addition 


D Decimal adjust for addition 


Tineger divide byte or word 


IDIV Integer divide byte or word 


DIV ivi 

AAD ASCII adjust for division 
CBW Convert byte to word 

CWD Convert word to doubleword 
MOVS Move byte or word string 


Pree | Revest SCS 


REPE/ . 
REPZ Repeat while equal/zero 
cea Repeat while not equal/not zero 


LOGICALS 
NOT "Not'' byte or word 
AND "And" byte or word 


"Inclusive or'' byte or word 
OR "Exclusive or'' byte or word 


Ee aie ee 
ROR | Rotate right byte or word =| 


wart 
LOCK Lock bus during next instruction 


Figure 3. 80188 Instruction Set 


All mnemonics copyright Intel Corp. 





JA/JNBE CALL Call procedure 
JC ITERATION CONTROLS 


Loop 


JL/JNGE Loop if not equal/not zero 
JLE/JNG JCXZ Jump if register CX = 0 
Pc a an 


N 


JNC 
JO i 


Jump if overflow IRET Interrupt return 
JP/JPE Jump if parity/parity even 


JS Jump if sign 


Figure 3. 80188 Instruction Set (continued) 


All mnemonics copyright Intel Corp. 


To access operands that do not reside in one of the four 
immediately available segments, a full 32-bit pointer can be 
used to reload both the base (segment) and offset values. 
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Table 3. Segment Register Selection Rule 
PROCESS 
DATA 
Memory Segment BLOCK 1 a 
Reference Register Implicit Segment 
Needed Used Selection Rule ! l 
| I 
! ' 


Instructions Code (CS) | Instruction prefetch and im- 
mediate data. PROCESS 


Stack Stack (SS) | All stack pushes and pops; 
any memory references 
which use BP Register as a 


base register. tid 


MEMORY 


External Extra (ES) | All string instruction refer- Drog2eso 


Data ences which use the DI reg- 
(Giopal) Istetc As: aP Index. Figure 5. Segmented Memory Helps 


Local Data Data (DS) | All other data references. Structure Software 








Addressing Modes 


The 80188 provides eight categories of addressing modes to 

specify operands. Two addressing modes are provided for 

instructions that operate on register or immediate operands: 

®@ Register Operand Mode: The operand is located in one of 
the 8- or 16-bit general registers. 

@ Immediate Operand Mode: The operand is included in the 
instruction. 





Six modes are provided to specify the location of an operand 

in a memory segment. A memory operand address consists of 

two 16-bit components: a segment base and an offset. The 

segment base is supplied by a 16-bit segment register either 

implicity chosen by the addressing mode or explicitly chosen 

by a segment override prefix. The offset, also called the 

effective address, is calculated by summing any combination 

of the following three address elements: 

@ the displacement (an 8- or 16-bit immediate value con- 
tained in the instruction); 

@ the base (contents of either the BX or BP base registers); 
and 

® the index (contents of either the SI or DI index registers) 


Any carry out from the 16-bit addition is ignored. Eight-bit 
displacements are sign extended to 16-bit values. 


Combinations of these three address elements define the six 

memory addressing modes, described below. 

@ Direct Mode: The operand's offset is contained in the 
instruction as an 8- or 16-bit displacement element. 

© Register Indirect Mode:The operand's offset is in one of the 
registers SI, DI, BX, or BP. 

@ Based Mode: The operand's offset is the sum of an 8- or 
16-bit displacement and the contents of a base register (BX 
or BP). 

@ Indexed Mode: The operand's offset is the sum of an 8- or 
16-bit displacement and the contents of an index register 
(SI or Dl). 

© Based Indexed Mode: The operand's offset is the sum of 
the contents of a base register and an index register. 

@ Based Indexed Mode with Displacement: The operand's 
offset is the sum of a base register's contents, an index 
register's contents, and an 8- or 16-bit displacement. 


Data Types 


The 80188 directly supports the following data types: 

®@ Integer: A signed binary numeric value contained in an 8-bit 
byte or a 16-bit word. All operations assume a 2's comple- 
ment representation. Signed 32 and 64 bit integers are 
supported using a numeric data processor. 

® Ordinal: An unsigned binary numeric value contained in an 
8-bit byte or a 16-bit word. 

© Pointer: A 16- or 32-bit quantity, composed of a 16-bit offset 
component or a 16-bit segment base component in addition 
to a 16-bit offset component. 

© String: A contiguous sequence of bytes or words. A string 
may contain from 1K to 64K bytes. 

@ ASCII: A byte representation of alphanumeric and control 
characters using the ASCII standard of character represen- 
tation. 

@ BCD: A byte (unpacked) representation of the decimal 
digits 0-9. 

© Packed BCD: A byte (packed) representation of two deci- 

mal digits (0-9). One digit is stored in each nibble (4-bits) of 

the byte. 








@ Floating Point: A signed 32-, 64-, or 80-bit real number 
representation. (Floating point operands are supported 
using a numeric data processor configuration.) 


In general, individual data elements must fit within defined 
segment limits. Figure 6 graphically represents the data types 
supported by the 80188. 
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NOTE: *SUPPORTED BY 80188 WITH A NUMERIC DATA 
PROCESSOR 


Figure 6. 80188 Supported Data Types 


1/O Space 


The I/O space consists of 64K 8-bit or 32K 16-bit ports. 
Separate instructions address the I/O space with either an 8- 
bit port address, specified in the instruction, or a 16-bit port 
address in the DX register, 8-bit port addresses are zero 
extended such that A15-Ag are LOW. |/O port addresses 
OOF8(H) through OOFF(H) are reserved. 


Interrupts 


An interrupt transfers execution to a new program location. 
The old program address (CS:IP) and machine state (Status 
Word) are saved on the stack to allow resumption of the 
interrupted program. Interrupts fall into three classes: hard- 
ware initiated, INT instructions, and instruction exceptions. 
Hardware initiated interrupts occur in response to an external 
input and are classified as non-maskable or maskable. 


Programs may cause an interrupt with an INT instruction. 
Instruction exceptions occur when an unusual condition, which 
prevents further instruction processing, is detected while 
attempting to execute an instruction. If the exception was 
caused by executing an ESC instruction with the ESC trap bit 
set in the relocation register, the return instruction will point to 
the ESC instruction, or to the segment override prefix immedi- 
ately preceding the ESC instruction if the prefix was present. 
In all other cases, the return address from an exception will 
point at the instruction immediately following the instruction 
causing the exception. 


A table containing up to 256 pointers defines the proper 
interrupt service routine for each interrupt. Interrupts 0-31, 
some of which are used for instruction exceptions, are 
reserved. Table 4 shows the 80188 predefined types and 
default priority levels. For each interrupt, an 8-bit vector must 
be supplied to the 80188 which identifies the appropriate table 
entry. Exceptions supply the interrupt vector internally. In 
addition, internal peripherals and noncascaded external inter- 
rupts will generate their own vectors through the internal 
interrupt controller. INT instructions contain or imply the vector 
and allow access to all 256 interrupts. Maskable hardware 
initiated interrupts supply the 8-bit vector to the CPU during an 
interrupt acknowledge bus sequence. Non-maskable hard- 
ware interrupts use a predefined internally supplied vector. 


Interrupt Sources 


The 80188 can service interrupts generated by software or 
hardware. The software interrupts are generated by specific 
instructions (INT, ESC, unused OP, etc.) or the results of 
conditions specified by instructions (array bounds check, 
INTO, DIV, IDIV, etc.) All interrupt sources are serviced by an 
indirect call through an element of a vector table. This vector 
table is indexed by using the interrupt vector type (Table 4), 
multiplied by four. All hardware-generated interrupts are sam- 
pled at the end of each instruction. Thus, the software 
interrupts will begin service first. Once the service routine is 
entered and interupts are enabled, any hardware source of 
sufficient priority can interrupt the service routine in progress. 


The software generated 80188 interrupts are described below. 
DIVIDE ERROR EXCEPTION (TYPE 0) 


Generated when a DIV or IDIV instuction quotient cannot be 
expressed in the number of bits in the destination. 
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Table 4. 80188 Interrupt Vectors 


Vector| Default Related 
Interrupt Name vee _ Instructions 


Divide Error DIV, IDIV 
Exception 

Single Step All 
Interrupt 

NMI 1 All 

Breakpoint | INT 
Interrupt 

INTO Detected 4 
Overflow 
Exception 

Array Bounds it 
Exception 

Unused-Opcode a 
Exception 

ESC Opcode 
Exception 

Timer O Interrupt 

Timer 1 Interrupt 

Timer 2 Interrupt 

Reserved 

DMA 0 Interrupt 

DMA 1 Interrupt 

INTO Interrupt 

INT1 Interrupt 

INT2 Interrupt 

INT3 Interrupt 


INTO 


BOUND 


Undefined 
Opcodes 
ik asa ESC Opcodes 
oAt*** 

oB**** 

ocrr* 


These are generated as the result of an instruction 
execution. 

This is handled as in the 8088. 

All three timers constitute one source of request to 
the interrupt controller. The Timer interrupts all have 
the same default priority level with respect to all other 
interrupt sources. However, they have a defined 
priority ordering amongst themselves. (Priority 2A is 
higher priority than 2B.) Each Timer interrupt has a 
separate vector type number. 

Default priorities for the interrupt sources are used 
only if the user does not program each source into a 
unique priority level. 

An escape opcode will cause a trap only if the proper 
bit is set in the peripheral control block relocation 
register. 


SINGLE-STEP INTERRUPT (TYPE 1) 

Generated after most instructions if the TF flag is set. 
Interrupts will not be generated after prefix instructions (e.g., 
REP), instructions which modify segment registers (e.g., POP 
DS), or the WAIT instruction. 

NON-MASKABLE INTERRUPT-NMI (TYPE 2) 

An external interrupt source which cannot be masked. 
BREAKPOINT INTERRUPT (TYPE 3) 

A one-byte version of the INT instruction. It uses 12 as an 


index into the service routine address table (because it is a 
type 3 interrupt). 





INTO DETECTED OVERFLOW EXCEPTION 
(TYPE 4) 


Generated during an INTO instruction if the OF bit is set. 
ARRAY BOUNDS EXCEPTION (TYPE 5) 


Generated during a BOUND instruction if the array index is 
outside the array.bounds. The array bounds are located in 
memory at a location indicated by one of the instruction 
operands. The other operand indicates the value of the index 
to be checked. 


UNUSED OPCODE EXCEPTION (TYPE 6) 
Generated if execution is attempted on undefined opcodes. 
ESCAPE OPCODE EXCEPTION (TYPE 7) 


Generated if execution is attempted of ESC opcodes (D8H- 
DFH). This exception will only be generated if a bit in the 
relocation register is set. The return address of this exception 
will point to the ESC instruction causing the exception. If a 
segment override prefix preceded the ESC instruction, the 
return address will point to the segment override prefix. 


Hardware-generated interrupts are divided into two groups: 
maskable interupts and non-maskable interrupts. The 80188 
provides maskable hardware interrupt request pins INTO- 
INT3. In addition, maskable interrupts may be generated by 
the 80188 integrated DMA controller and the integrated timer 
unit. The vector types for these interrupts is shown in Table 4. 
Software enables these inputs by setting the interrupt flag bit 
(IF) in the Status Word. The interrupt controller is discussed in 
the peripheral section of this data sheet. 


Further maskable interrupts are disabled while servicing an 
interrupt because the IF bit is reset as part of the response to 
an interrupt or exception. The saved Status Word will reflect 
the enable status of the processor prior to the interrupt. The 
interrupt flag will remain zero unless specifically set. The 
interrupt return instruction restores the Status Word, thereby 
restoring the original status of IF bit. If the interrupt return re- 
enables interrupts, and another interrupt is pending, the 80188 
will immediately service the highest-priority interrupt pending, 
i.e., no instructions of the main line program will be executed. 


Non-Maskable Interrupt Request (NMI) 


A non-maskable interrupt (NMI) is also provided. This interrupt 
is serviced regardless of the state of the IF bit. A typical use of 
NMI would be to activate a power failure routine. The 
activation of this input causes an interrupt with an internally 
supplied vector value of 2. No external interrupt acknowledge 
sequence is performed. The IF bit is cleared at the beginning 
of an NMI interrupt to prevent maskable interrupts from being 
serviced. 


Single-Step Interrupt 


The 80188 has an internal interrupt that allows programs to 
execute one instruction at a time. It is called the single-step 
interrupt and is controlled by the single-step flag bit (TF) in the 
Status Word. Once this bit is set, an internal single-step 
interrupt will occur after the next instruction has been execut- 
ed. The interrupt clears the TF bit and uses an internally 
supplied vector of 1. The IRET instruction is used to set the TF 
bit and transfer control to the next instruction to be single- 
stepped. 


Initialization and Processor Reset 


Processor initialization or startup is accomplished by driving 
the RES input pin LOW. RES forces the 80188 to terminate all 
execution and local bus activity. No instruction or bus activity 
will occur as long as RES is active. After RES becomes 











inactive and an internal processing interval elapses, the 80188 
begins execution with the instruction at physical location 
FFFFO(H). RES also sets some registers to predefined values 
as shown in Table 5. 


Table 5. 80188 Initial Register State after RESET 


Relocation Register 


THE 80188 COMPARED TO THE 80186 












The 80188 CPU is an 8-bit processor designed around the 
80186 internal structure. Most internal functions of the 80188 
are identical to the equivalent 80186 functions. The 80188 
handles the external bus the same way the 80186 does with 
the distinction of handling only 8 bits at a time. Sixteen bit 
operands are fetched or written in two consecutive bus cycles. 
Both processors will appear identical to the software engineer, 
with the exception of execution time. The internal register 
structure is identical and all instructions have the same end 
result. The differences between the 80188 and 80186 are 
outlined below. Internally, there are three differences between 
the 80188 and the 80186. All changes are related to the 8-bit 
bus interface. 

@ The queue length is 4 bytes in the 80188, whereas the 
80186 queue contains 6 bytes, or three words. The queue 
was shortened to prevent overuse of the bus by the BIU 
when prefetching instructions. This was required because 
of the additional time necessary to fetch instructions 8 bits 
at a time. 

@ To further optimize the queue, the prefetching algorithm 
was changed. The 80188 BIU will fetch a new instruction to 
load into the queue each time there is a 1-byte hole (space 
available) in the queue. The 80186 waits until a 2-byte 
space is available. ; 

© The internal execution time of the instruction is affected by 
the 8-bit interface. All 16-bit fetches and writes from/to 
memory take an additional four clock cycles. The CPU may 
also be limited by the speed of instruction fetches when a 
series of simple operations occurs. When the more sophis- 
ticated instructions of the 80188 are being used, the queue 
has time to fill and the execution proceeds as fast as the 
execution unit will allow. 


The 80188 and 80186 are completely software compatible by 
virtue of their identical execution units. Software that is system 
dependent may not be completely transferable, but software 
that is not system dependent will operate equally well on an 
80188 or an 80186. 


The hardware interface of the 80188 contains the major 

differences between the two CPUs. The pin assignments are 

nearly identical, however, with the following functional changes. 

@ A8-A15—These pins are only address outputs on the 
80188. These address lines are latched internally and 
remain valid throughout a bus cycle in a manner similar to 
the 8085 upper address lines. 

@ BHE has no meaning on the 80188 and has been eliminated. 


80188 CLOCK GENERATOR 


The 80188 provides an on-chip clock generator for both 
internal and external clock generation. The clock generator 
features a crystal oscillator, a divide-by-two counter, synchro- 
nous and asynchronous ready inputs, and reset circuitry. 


Oscillator 


The oscillator circuit of the 80188 is designed to be used with 
a parallel resonant fundamental mode crystal. This is used as 
the time base for the 80188. The crystal frequency selected 
will be double the CPU clock frequency. Use of an LC or RC 
circuit is not recommended with this oscillator. If an external 
oscialltor is used, it can be connected directly to input pin X1 in 
lieu of a crystal. The output of the oscillator is not directly 
available outside the 80188. The recommended crystal config- 
uration is shown in Figure 7. 


TC001852 


X= 20 for 10 MHz (80188-1) 
X = 16 for 8 MHz (80188-3) 
X=4 


2 for 6 MHz (80188-6) 


Figure 7. Recommended 80188 Crystal 
Configuration 


Clock Generator 


The 80188 clock generator provides the 50% duty cycle 
processor clock for the 80188. It does this by dividing the 
oscillator output by 2 forming the symmetrical clock. If an 
external oscillator is used, the state of the clock generator will 
change on the falling edge of the oscillator signal. The 
CLKOUT pin provides the processor clock signal for use 
outside the 80188. This may be used to drive other system 
components. All timings are referenced to the output clock. 


READY Synchronization 


The 80188 provides both synchronous and asynchronous 
ready inputs. Asynchronous ready synchronization is accom- 
plished by circuitry which samples ARDY in the middle of To, 
Tg and again in the middle of each Tw until ARDY is sampled 
HIGH. One-half CLKOUT cycle of resolution time is used. Full 
synchronization is performed only on the rising edge of ARDY, 
i.e., the falling edge of ARDY must be synchronized to the 
CLKOUT signal if it will occur during To or Ty. HIGH-to-LOW 
transitions of ARDY must be performed synchronously to the 
CPU clock. 


A second ready input (SRDY) is provided to interface with 
externally synchronized ready signals. This input is sampled at 
the end of To and again at the end of each Tw until it is 
sampled HIGH. By using this input rather than the asynchro- 
nous ready input, the half-clock cycle resolution time penalty is 
eliminated. 


This input must satisfy set-up and hold times to guarantee 
proper operation of the circuit. 
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In addition, the 80188, as part of the integrated chip-select 
logic, has the capability to program WAIT states for memory 
and peripheral blocks. This is discussed in the Chip Select/ 
Ready Logic description. 


RESET Logic 


The 80188 provides both a RES input pin and a synchronized 
RESET pin for use with other system components. The RES 
input pin on the 80188 is provided with hysteresis in order to 
facilitate power-on Reset generation via an RC network. 
RESET is guaranteed to remain active for at least five clocks 
given a RES input of at least six clocks. RESET may be 
delayed up to two and one-half clocks behind RES. 


Multiple 80188 processors may be synchronized through the 
RES input pin, since this input resets both the processor and 
divide-by-two internal counter in the clock generator. In order 
to insure that the divide-by-two counters all begin counting at 
the same time, the active going edge of RES must satisfy a 25 
ns setup time before the falling edge of the 80188 clock input. 
In addition, in order to insure that all CPUs begin executing in 
the same clock cycle, the reset must satisfy a 25 ns setup time 
before the rising edge of the CLKOUT signal of all the 
processors. 


LOCAL BUS CONTROLLER 


The 80188 provides a local bus controller to generate the local 
bus control signals. In addition, it employs a HOLD/HLDA 
protocol for relinquishing the local bus to other bus masters. It 
also provides control lines that can be used to enable external 
buffers and to direct the flow of data on and off the local bus. 


Memory/Peripheral Control 


The 80188 provides ALE, RD, and WR bus control signals. 
The RD and WR signals are used to strobe data from memory 
to the 80188 or to strobe data from the 80188 to memory. The 
ALE line provides a strobe to address latches for the multi- 
plexed address/data bus. The 80188 local bus controller does 
not provide a memory/I/O signal. If this is required, the user 
will have to use the S2 signal (which will require external 
latching), make the memory and I/O spaces nonoverlapping, 
or use only the integrated chip-select circuitry. 


Transceiver Control 


The 80188 generates two control signals to be connected to 
2946/2947 transceiver chips. This capability allows the addi- 
tion of transceivers for extra buffering without adding external 
logic. These control lines, DT/R and DEN, are generated to 
control the flow of data through the transceivers. The opera- 
tion of these signals is shown in Table 6. 


Table 6. Transceiver Control Signals Description 


DEN (Data Enable) Enables the output drivers of the 
transceivers. It is active LOW 
during memory, !/O, or INTA 
cycles. 

Determines the direction of trav- 
el through the transceivers. A 
HIGH level directs data away 
from the processor during write 
operations, while a LOW level 
directs data toward the proces- 
sor during a read operation. 


DT/R (Data Transmit/ 
Receive) 





Local Bus Arbitration 


The 80188 uses a HOLD/HLDA system of local bus ex- 
change. This provides an asynchronous bus exchange mecha- 
nism. This means multiple masters utilizing the same bus can 
operate at separate clock frequencies. The 80188 provides a 
single HOLD/HLDA pari through which all other bus masters 
may gain cotnrol of the local bus. This requires external 
circuitry to arbitrate whcih external device will gain control of 
the bus from the 80188 when there is more than one alternate 
local bus master. When the 80188 relinquishes control of the 


A19, S7 and DT/R to allow another master to drive these lines 
directly. 


The 80188 HOLD latency time, i.e., the time between HOLD 
request and HOLD acknowledge, is a function of the activity 
occurring in the processor when the HOLD request is re- 
ceived. A HOLD request is the highest-priority activity request 
which the processor may receive: higher than instruction 
fetching or internal DMA cycles. However, if a DMA cycle is in 
progress, the 80188 will complete the transfer before relin- 
quishing the bus. This implies that if a HOLD request is 
received just as a DMA transfer begins, the HOLD latency time 
can be as great as 4 bus cycles. This will occur if a DMA word 
transfer operation is taking place from an odd address to an 
odd address. This is a total of 16 clocks or more, if WAIT 
states are required. In addition, if locked transfers are per- 
formed, the HOLD latency time will be increased by the length 
of the locked transfer. 


Local Bus Controller and Reset 


Upon receipt of a RESET pulse from the RES input, the local 
bus controller will perform the following actions: 


@ Drive DEN, RD, and WR HIGH for one clock cycle, then 
float. 


NOTE: RE is also provided with an internal pull-up de- 
vice to prevent the processor from inadvertently enter- 
ing Queue Status mode during reset. 


Drive SO-S2 to the passive state (all HIGH) and then float. 
Drive LOCK HIGH and then float. 

Tristate ADO-AD7, A8-A19, S7, DT/R 

Drive ALE LOW (ALE is never floated). 

Drive HLDA LOW. 


INTERNAL PERIPHERAL INTERFACE 


All the 80188 integrated peripherals are controlled via 16-bit 
registers contained within an internal 256-byte control block. 
This control block may be mapped into either memory or I/O 
space. Internal logic will recognize the address and respond to 
the bus cycle. During bus cycles to internal registers, the bus 
controller will signal the operation externally (i.e., the RD, WR, 
status, address, data, etc., lines will be driven as in a normal 
bus cycle), but D7.9, SRDY, and ARDY will be ignored. The 
base address of the control block must be on an even 256- 
byte boundary (i.e., the lower 8 bits of the base address are all 
zeros). All of the defined registers within this control block may 
be read or written by the 80186 CPU at any time. The location 
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of any register contained within the 256-byte control block is 
determined by the current base address of the control block. 


The control block base address is programmed via a 16-bit 
relocation register contained within the control block at offset 
FEH from the base address of the control block (see Figure 8). 
It provides the upper 12 bits of the base address of the control 
block. Note that mapping the control register block into an 
address range corresponding to a chip-select range is not 
recommended (the chip select circuitry is discussed later in 
this date sheet). In addition, bit 12 of this register determines 
whether the control block will be mapped into I/O or memory 
space. If this bit is 1, the control block will be located in 
memory space, whereas if the bit is 0, the control block will be 
located in I/O space. If the control register block is mapped 
into I/O space, the upper 4 bits of the base address must be 
programmed as 0 (since I/O addresses are only 16 bits wide). 


In addition to providing relocation information for the control 
block, the relocation register contains bits which place the 
interrupt controller into IRMX mode, and cause the CPU to 
interrupt upon encountering ESC instructions. At RESET, the 
relocation register is set to 20FFH. This causes the control 
block to start at FFOOH in I/O space. An offset map of the 256- 
byte control register block is shown in Figure 9. 


The integrated 80188 peripherals operate semiautonomously 
from the CPU. Access to them for the most part is via software 
read/write of the control and data locations in the control 
block. Most of these registers can be both read and written. A 
few dedicated lines, such as interrupts and DMA request 
provide real-time communication between the CPU and pe- 
ripherals as in a more conventional system utilizing discrete 
peripheral blocks. The overall interaction and function of the 
peripheral blocks has not substantially changed. 


CHIP-SELECT/READY GENERATION LOGIC 


The 80188 contains logic which provides programmable chip- 
select generation for both memories and peripherals. In 
addition, it can be programmed to provide READY (or WAIT 
state) generation. It can also provide latched address bits A1 
and A2. The chip-select lines are active for all memory and I/O 
cycles in their programmed areas, whether they be generated 
by the CPU or by the integrated DMA unit. 


Memory Chip Selects 


The 80188 provides 6 memory chip select outputs for 3 
address areas: upper memory, lower memory, and midrange 
memory. One each is provided for upper memory and lower 
memory, while four are provided for midrange memory. 


The range for each chip select is user-programmable and can 
be set to 2K, 4K, 8K, 16K, 32K, 64K, 128K (plus 1K and 256K 
for upper and lower chip selects). In addition, the beginning or 
base address of the midrange memory chip select may also be 
selected. Only one chip select may be programmed to be 
active for any memory location at a time. All chip select sizes 
are in bytes, whereas 80188 memory is arranged in words. 
This means that if, for example, 16 64K x 1 memories are 
used, the memory block size will be 128K, not 64K. 


8 7 6 5 4 3 2 1 0 


1312 
OFFSET: FEH| ET [RMX| | M/IO Relocation Address Bits R19-R8 


ET =ESC Trap/No ESC Trap (1/0) 


M/IO = Register block located in Memory / 1/O Space (1/0) 
RMX = Normal Interrupt Controller mode / IRMX compatible Interrupt Controller mode (0/1) 


Figure 8. Relocation Register 
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OFFSET 
FEH 


Relocation Register 
DMA Descriptors Channel 1 
DMA Descriptors Channel 0 
Chip-Select Control Registers 

Timer 2 Control Registers 
Timer 1 Control Registers 
Timer 0 Control Registers 
Interrupt Controller Registers 


Figure 9. Internal Register Map 


Upper Memory CS 


The 80188 provides a chip select, called UCS, for the top of 
memory. The top of memory is usually used as the system 
memory because after reset the 80188 begins executing at 
memory location FFFFOH. 


The upper limit of memory defined by this chip select is always 
FFFFFH, while the lower limit is programmable. By program- 
ming the lower limit, the size of the select block is also 
defined. Table 7 shows the relationship between the base 
address selected and the size of the memory block obtained. 


Table 7. UMCS Programming Values 
Starting 


Address 
(Base 


UMCS Value 
(Assuming 
RO =R1=R2=0) 


The lower limit of this memory block is defined in the UMCS 
register (see Figure 10). This register is at offset AOH in the 
internal control block. The legal values for bits 6-13 and the 
resulting starting address and memory block sizes are given in 
Table 7. Any combination of bits 6-13 not shown in Table 7 will 
result in undefined operation. After reset, the UMCS register is 
programmed for a 1K area. It must be reprogrammed if a 
larger upper memory area is desired. 


Any internally generally 20-bit address whose upper 16-bits 
are greater than or equal to UMCS (with bits 0-5 ''0") will 
cause UCS to be activated. UMCS bits R2-RO are used to 
specify READY mode for the area of memory defined by this 
chip-select register, as explained below. 


Lower Memory CS 


The 80188 provides a chip select for low memory called LCS. 
The bottom of memory contains the interrupt vector table, 
starting at location O0O00H. 


The lower limit of memory defined by this chip select is always 
OH, while the upper limit is programmable. By programming 
the upper limit, the size of the memory block is also defined. 
Table 8 shows the relationship between the upper address 
selected and the size of the memory block obtained. 


Table 8. LMCS Programming Values 
LMCS Value 


(Assuming 
RO = R1=R2=0) 


Memory 
Upper Block 


Address 


003FFH 
007FFH 
OOFFFH 
01FFFH 
O3FFFH 
O7FFFH 
OFFFFH 
1FFFFH 
3FFFFH 


The upper limit of this memory block is defined in the LMCS 
register (see Figure 11). This register is at offset A2H in the 
internal contro! block. The legal values for bits 6-15 and the 
resulting upper address and memory block sizes are given in 
Table 8. Any combination of bits 6-15 not shown in Table 8 will 
result in undefined operation. After reset, the LMCS register 
value is undefined. However, the LCS chip-select line will not 
become active until the LMCS register is accessed. 


Any internally generated 20-bit address whose upper 16 bits 
are less than or equal to LMCS (with bits 0-5 ''1"') will cause 
ICS to be active. LMCS register bits R2-RO are used to 
specify the READY mode for the area of memory defined by 
this chip-select register. 


Mid-Range Memory CS 


The 80188 provides four MCS lines which are active within a 
user-locatable memory block. This block can be located 
anywhere within the 80188 1M byte memory address space 
exclusive of the areas defined by UCS and LCS. Both the base 
address and size of this memory block are programmable. 


The size of the memory block defined by the midrange select 
lines, as shown in Table 9, is determined by bits 8-14 of the 
MPCS register (see Figure 12). This register is at location A8H 
in the internal control block. One and only one of bits 8-14 
must be set at a time. Unpredictable operation of the MCS 
lines will otherwise occur. Each of the four chip-select lines is 
active for one of the four equal contiguous divisions of the mid- 
range block. Thus, if the total block size is 23K, each chip 
select is active for 8K of memory with MCSO being active for 
the first range and MCS3 being active for the last range. 


The EX and MS in MPCS relate to peripheral functionally as 
described in a later section. 





Table 9. MMCS Programming Values 


Total Block Individual MNCS Bits 
Size Select Size 14-8 


0000001B 
0000010B 
0000100B 
0001000B 
00100008 
0100000B 
1000000B 


The base address of the mid-range memory block is defined 
by bits 15-9 of the MMCS register (see Figure 13). This 
register is at offset A6H in the internal control block. These 
bits correspond to bits A19-A13 of the 20-bit memory address. 
Bits A12-A0 of the base address area always 0. The base 
address may be set at any integer multiple of the size of the 
total memory block selected. For example, if the midrange 
block size is 32K (or the size of the block for which each MCS 
line is active is 8K), the block could be located at 10000H or 
18000H, but not at 14000H, since the first few integer 
multiples of a 32K memory block are OH, 8000H, 10000H, 
18000H, etc. After reset, the contents of both of these 
registers is undefined. However, none of the MCS lines will be 
active until both the MMCS and MPCS registers are accessed. 


Figure 11. LMCS Register 
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Figure 12. MPCS Register 


Figure 13. MMCS Register 


MMCS bits R2-RO specify READY mode of operation for all 
mid-range chip selects. All devices in mid-range memory must 
use the same number of WAIT states. 


The 512K block size for the mid-range memory chip selects is 
a special case. When using 512K, the base address would 
have to be at either locations O0000H or 80000H. If it were to 
be programmed at 00000H when the LCS line was pro- 
grammed, there would be an internal conflict between the Lcs 
ready generation logic and the MCS ready generation logic. 
Likewise, if the base address were programmed at 80000H, 
there would be a conflict with the UCS ready generation logic. 
Since the LCS chip-select line does not become active until 
programmed, while the UCS line is active at reset, the memory 
base can be set only at OOOOOH. If this base address is 
selected, however, the LCS range must not be programmed. 
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Peripheral Chip Selects 


The 80188 can generate chip selects for up to seven 
peripheral devices. These chip selects are active for seven 
contiguous blocks of 128 bytes above a programmable base 
address. This base address may be located in either memory 
or I/O space. 


Seven CS lines called PCSO-6 are generated by the 80188. 
The base address is user-programmable; however it can only 
be a multiple of 1K bytes, i.e., the least significant 10 bits of 
the starting address are always 0. 


PCS5 and PCS6 can also be programmed to provide latched 
address bits A1, A2. If so programmed, they cannot be used 
as peripheral selects. These outputs can be connected 
directly to the AO, A1 pins used for selecting internal registers 
of 8-bit peripheral chips. This scheme simplifies the hardware 
interface because the 8-bit registers of peripherals are simply 








treated as 16-bit registers located on even boundaries in I/O 
space or memory space where only the lower 8-bits of the 
register are significant: the upper 8-bits are "don't cares." 


The starting address of the peripheral chip-select block is 
defined by the PACS register (see Figure 14). This register is 
located at offset A4H in the internal control block. Bits 15-6 of 
this register correspond to bits 19-10 of the 20-bit Programma- 


15 
OFFSET: A4H 
A19 





The user should program bits 15-6 to correspond to the 
desired peripheral base location. PACS bits 0-2 are used to 
specify READY mode for PCSO-PCS3. 





Table 10. PCS Address Ranges 


PCS Line Active between Locations 


PBA — PBA + 127 
PBA + 128 — PBA + 255 
PBA + 256 — PBA + 383 
PBA + 384 — PBA + 511 
PBA + 512 — PBA + 639 
PBA + 640 — PBA + 767 
PBA + 768 — PBA + 895 
































The mode of operation of the peripheral chip selects is defined 
by the MPCS register (which is also used to set the size of the 
mid-range memory chip-select block, see Figure 15). This 
register is located at offset A8H in the internal control block. 
Bit 7 is used to select the function of PCS5 and PCS6, while bit 
6 is used to select whether the peripheral chip selects are 
mapped into memory or I/O space. Table 11 describes the 
programming of these bits. After reset, the contents of both 
the MPCS and the PACS registers are undefined, however 
none of the PCS lines will be active until both of the MPCS and 
PACS registers are accessed. 





Table 11. MS, EX Programming Values 


1 = Peripherals mapped into memory space. 
0 = Peripherals mapped into |/O space. 

0=5 PCS lines. A1, A2 provided. 

1=7 PCS lines. A1, A2 are not provided. 







MPCS bits 0-2 are used to specify READY mode for PCS4- 
PCS6 as outlined below. 


READY Generation Logic 


The 80188 can generate a '"'READY'"' signal internally for each 
of the memory or peripheral CS lines. The number of WAIT 
states to be inserted for each peripheral or memory is 
programmable to provide 0-3 wait states for all accesses to 
the area for which the chip select is active. In addition, the 
80188 may be programmed to either ignore external READY 
for each chip- select range individually or to factor external 
READY with the integrated ready generator. 
























Figure 14. PACS Register 





ble Base Address (PBA) of the peripheral chip-select block. 
Bits 9-0 of the PBA of the peripheral chip-select block are all 
zeros. If the chip-select block is located in I/O space, bits 12- 
15 must be programmed zero, since the I/O address is only 16 
bits wide. Table 10 shows the address range of each 
peripheral chip select with respect to the PBA contained in 
PACS register. 


READY control consists of 3 bits for each CS line or group of 
lines generated by the 80188. The interpretation of the ready 
bits is shown in Table 12. 


Table 12. READY Bits Programming 


Number of WAIT States Generated 


0 wait states, external RDY also used. 

1 wait state inserted, external RDY also 
used. 

2 wait states inserted, external RDY also 
used. 

3 wait states inserted, external RDY also 
used. 

0 wait states, external RDY ignored. 

1 wait state inserted, external RDY 
ignored. 

2 wait states inserted, external RDY ig- 
nored. 

3 wait states inserted, external RDY ig- 
nored. 


















The internal ready generator operates in parallel with external 
READY, not in series if the external READY is used (R2 = 0). 
This means, for example, if the internal generator is set to 
insert two wait states, but activity on the external READY lines 
will insert four wait states, the processor will only insert four 
wait states, not six. This is because the two wait states 
generated by the internal generator overlapped the first two 
wait states generated by the external ready signal. Note that 
the external ARDY and SRDY lines are always ignored during 
cycles accessing internal peripherals. 


R2-RO of each control word specifies the READY mode for the 
corresponding block, with the exception of the peripheral chip 
selects: R2-RO of PACS set the PCS0-3 READY mode, R2-RO 
of MPCS set the PCS4-6 READY mode. 





Chip Select/Ready Logic and Reset 


Upon reset, the Chip-Select/Ready Logic will perform the 

following actions: 

© All chip-select outputs will be driven HIGH. 

® Upon leaving RESET, the UCS line will be programmed to 
provide chip selects to a 1K block with the accompanying 
READY control bits set at 011 to allow the maximum 
number of internal wait states in conjunction with external 

Ready consideration (i.e. UMCS resets to FFFBH). 


11 10 
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Figure 15. MPCS Register 


No other chip select or READY control registers have any 
predefined values after RESET. They will not become 
active until the CPU accesses their control registers. Both 
the PACS and MPCS registers must be accessed before 
the PCS lines will become active. 


DMA CHANNELS 


The 80188 DMA controller provides two independent high- 
speed DMA channels. Data transfers can occur between 
memory and !/O spaces (e.g., Memory to I/O) or within the 
same space (e.g., Memory to Memory or I/O to I/O). Data can 
be transferred either in bytes (8 bits) or in words (16 bits) to or 
from even or odd addresses. Each DMA channel maintains 
both a 20-bit source and destination pointer which can be 
optionally incremented or decremented after each data trans- 
fer (by one or two depending on byte or word transfers). Each 
data transfer consumes 2 bus cycles (a minimum of 8 clocks), 
one cycle to fetch data and the other to store data. This 
provides a maximum data transfer rate of one Mword/sec or 2 
MBytes/sec. 


DMA Operation 


Each channel has six registers in the control block which 
define each channel's specific operation. The control registers 


20 BIT ADDER/SUBTRACTOR | : eae Oe 


consist of a 20-bit Source pointer (2 words), a 20-bit Destina- 
tion pointer (2 words), a 16-bit Transfer Counter, and a 16-bit 
Control Word. The format of the DMA Control Blocks is shown 
in Table 13. The Transfer Count Register (TC) specifies the 
number of DMA transfers to be performed. Up to 64K byte or 
word transfers can be performed with automatic termination. 
The Control Word defines the channel's operation (see Figure 
17). All registers may be modified or altered during any DMA 
activity. Anyl changes made to these registers will be reflected 
immediately in DMA operation. 


Table 13. DMA Control Block Format 


Register Address 
Register Name | Ch. 0] Ch. 1 | 


Control Word 

Transfer Count 

Destination Pointer (upper 4 bits) 
Destination Pointer 

Source Pointer (upper 4 bits) 
Source Pointer 


TIMER REQUEST 


REQUEST 
SELECTION 
LOGIC 


CHANNEL CONTROL WORD 0 


| CHANNEL CONTROL WORD 1 


INTERNAL ADDRESS/DATA BUS 
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Figure 16. DMA Unit Block Diagram 





M/ DESTINATION| M/ SOURCE 
10 DEC INC} 10 DEC INC 


X = DON'T CARE 
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Figure 17. DMA Control Register 


DMA Channel Control Word Register 


Each DMA Channel Control Word determines the mode of 
operation for the particular 80188 DMA channel. This register 
specifies: 


® the mode of synchronization; 

@ whether bytes or words will be transferred; 

@ whether interrupts will be generated after the last transfer; 

@ whether DMA activity will cease after a programmed 
number of DMA cycles; 
the relative priority of the DMA channel with respect to the 
other DMA channel; 
whether the source pointer will be incremented, decrement- 
ed, or maintained constant after each transfer; 
whether the source pointer addresses memory or |/O 
space; 
whether the destination pointer will be incremented, dec- 
remented, or maintained constant after each transfer; and 
whether the destination pointer will address memory or I/O 
space. 


The DMA channel control registers may be changed while the 
channel is operating. However, any changes made during 
operation will affect the current DMA transfer. 


DMA Control Word Bit Descriptions 


Bw: 
ST/STOP: 
CHG/NOCHG: 


Byte/Word (0/1) Transfers. 
Start/stop (1/0) Channel. 


Change/Do not change (1/0) ST/ 
STOP bit. If this bit is set when writing 
to the control word, the ST/STOP bit 
will be programmed by the write to 
the control word. If this bit is cleared 
when writing the control word, the 
ST/STOP bit will not be altered. This 
bit is not stored; it will always be a 0 
on read. 


Enable Interrupts to CPU on byte 
count termination. 


If set, DMA will terminate when the 
contents of the Transfer Count 
register reach zero. The ST/STOP bit 
will also be reset at this point if TC is 
set. If this bit is cleared, the DMA unit 
will decrement the transfer count 
register for each DMA cycle, but the 
DMA transfer will not stop when the 
contents of the TC register reach 
zero. 
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SYN: 
(2 bits) 


00 No synchronization 
NOTE: The ST bit will be cleared 
automatically when the contents 
of the TC register reach zero re 
gardless of the state of the bit. 

01 Source synchronization. 

10 Destination synchronization. 


11 Unused. 
Increment source pointer by 1 or 2 


(depends on B/W) after each 
transfer. 


SOURCE: INC 


M/I Source pointer is in M/IO space (1/ 


0). 


Decrement source pointer by 1 or 2 
(depends on B/W) after each 
transfer. 


DEST: INC Increment destination pointer by 1 or 


2 (B/W) after each transfer. 
Destination pointer is in M/IO space 
(1/0). 


Decrement destination pointer by 1 
or 2 (depending‘on B/W) after each 
transfer. 


M/I 


DEC 


Channel priority-relative to other 
channel. 

0 low priority. 

1 high priority. 

Channels will alternate cycles if 
both set at same priority level. 


0: Disable DMA requests from timer 
2. 
1: Enable DMA requests from timer 2. 


Bit 3 Bit 3 is not used. 
If both INC and DEC are specified for the same pointer, the 
pointer will remain constant after each cycle. 


DMA Destination and Source Pointer 
Registers 


Each DMA channel maintains a 20-bit source and a 20-bit 
destination pointer. Each of these pointers takes up two full 
16-bit registers in the peripheral control block. The lower four 
bits of the upper register contain the upper four bits of the 20- 
bit physical address (see Figure 18). These pointers may be 
individually incremented or decremented after each transfer. If 
word transfers are performed the pointer is incremented or 
decremented by two. Each pointer may point into either 
memory or I/O space. Since the DMA channels can perform 
transfers to or from odd addresses, there is no restriction on 
values for the pointer registers. Higher transfer rates can be 
obtained if all word transfers are performed to even ad- 











dresses, since this will allow data to be accessed in a single 
memory access. 





DMA Transfer Count Register 


Each DMA channel maintains a 16-bit transfer count register 
(TC). This register is decremented after every DMA cycle, 
regardless of the state of the TC bit in the DMA Control 
Register. If the TC bit in the DMA control word is set, however, 
DMA activity will terminate when the transfer count register 
reaches zero. 


DMA Requests 


Data transfers may be either source or destination synchro- 
nized, that is either the source of the data or the destination of 
the data may request the data transfer. In addition, DMA 
transfers may be unsynchronized; that is, the transfer will take 
place continually until the correct number of transfers has 
occurred. When source or unsynchronized transfers are per- 
formed, the DMA channel may begin another transfer immedi- 
ately after the end of a previous DMA transfer. This allows 
complete transfer to take place every 2 bus cycles or eight 
clock cycles (assuming no wait states). No prefetching occurs 





HIGHER 
REGISTER 
ADDRESS 


LOWER 
REGISTER 
ADDRESS 
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DMA Acknowledge 


No explicit DMA acknowledge pulse is provided. Since both 
source and destination pointers are maintained, a read from a 
requesting source, or a write to a requesting destination, 
should be used as the DMA acknowledge signal. Since the 
chip-select lines can be programmed to be active for a given 
block of memory or I/O space, and the DMA pointers can be 
programmed to point to the same given block, a chip-select 
line could be used to indicate a DMA acknowledge. 


DMA Priority 


The DMA channels may be programmed such that one 
channel is always given priority over the other, or they may be 
programmed such as to alternate cycles when both have DMA 
requests pending. DMA cycles always have priority over 
internal CPU cycles except between locked memory accesses 
or word accesses the odd memory locations; however, an 
external bus hold takes priority over an internal DMA cycle. 
Because an interrupt request cannot suspend a DMA opera- 
tion and the CPU cannot access memory during a DMA cycle, 
interrupt latency time will suffer during sequences of continu- 
ous DMA cycles. An NMI request, however, will cause all 
internal DMA activity to halt. This allows the CPU to quickly 
respond to the NMI request. 


DMA Programming 


DMA cycles will occur whenever the ST/STOP bit of the Control 
Register is set. If synchronized transfers are programmed, a 





ais-ai2 | atte 


Figure 18. DMA Memory Pointer Register Format 





when destination synchronization is performed, however. Data 
will not be fetched from the source address until the destina- 
tion device signatls that it is ready to receive it. When 
destination synchronized transfers are requested, the DMA 
controller will relinquish control of the bus after every transfer. 
If no other bus activity is initiated, another DMA cycle will 
begin after two processor clocks. This is done to allow the 
destination device time to remove its request if another 
transfer is not desired. Since the DMA controller will relinquish 
the bus, the CPU can initiate a bus cycle. As a result, a 
complete bus cycle will often be inserted between destination 
synchronized transfers. These lead to the maximum DMA 
transfer rates shown in Table 14. 


Table 14. Maximum DMA Transfer Rates 
with 8 MHz 80188 


Type of 
CPU Halted 


Synchronization 
Selected 
Unsynchronized 1 Mbytes/sec 1 Mbytes/sec 
1 Mbytes/sec 1 Mbytes/sec 
.65 Mbytes/sec | .75 Mbytes/sec 


Source Synch 
Destination Synch 
- A3- AO 
0 










































DRQ must also have been generated. Therefore, the source 
and destination transfer pointers, and the transfer count register 
(if used) must be programmed before this bit is set. 


Each DMA register may be modified while the channel is 
operating. If the CHG/NOCHG bit is cleared when the control 
register is written, the ST/STOP bit of the control register will 
not be modified by the write. If multiple channel registers are 
modified, it is recommended that a LOCKED string transfer be 
used to prevent a DMA transfer from occurring between 
updates to the channel registers. 


DMA Channels and Reset 


Upon RESET, the DMA channels will perform the following 
actions: 

@ The Start/Stop bit for each channel will be rest to STOP. 
@ Any transfer in progress is aborted. 


TIMERS 


The 80188 provides three internal 16-bit programmable timers 
(see Figure 19). Two of these are highly flexible and are 
connected to four external pins (2 per timer). They can be 
used to count external events, time external events, generate 
nonrepetitive waveforms, etc. The third timer is not connected 
to any external pins, and is useful for real-time coding and time 
delay applications. In addition, this third timer can be used as a 
prescaler to the other two, or as a DMA request source. 















ALL 16 BIT REGISTERS 


Timer Operation 


The timers are controlled by 11 16-bit registers in the internal 
peripheral control block. The configuration of these registers is 
shown in Table 15. The count register contains the current 
value of the timer. It can be read or written at any time 
independent of whether the timer is running or not. The value 
of this register will be incremented for each timer event. Each 
of the timers is equipped with a MAX COUNT register, which 
defines the maximum count the timer will reach. After reaching 
the MAX COUNT register value, the timer count value will 
reset to zero during that same clock, i.e., the maximum count 
value is never stored in the count register itself. Timers 0 and 1 
are, in addition, equipped with a second MAX COUNT register, 
which enables the timers to alternate their count between two 
different MAX COUNT values programmed by the user. If a 
single MAX COUNT register is used, the timer output pin will 
switch LOW for a single clock, 2 clocks after the maximum 
count value has been reached. In the dual MAX COUNT 
register mode, the output pin will indicate which MAX COUNT 
register is currently in use, thus allowing nearly complete 
freedom in selecting waveform duty cycles. For the timers with 
two MAX COUNT registers, the RIU bit in the control register 
determines which is used for the comparison. 


Each timer gets serviced every fourth CPU-clock cycle, and 
thus can operate at speeds up to one-quarter the internal 
clock frequency (one-eighth the crystal rate). External clocking 
of the timers may be done at up to a rate of one-quarter of the 
internal CPU-clock rate (2 MHz for an 8 MHz CPU clock). Due 
to internal synchronization and pipelining of the timer circuitry, 
a timer output may take up to 6 clocks to respond to any 
individual clock or gate input. 


15 14 13 12 1 
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MAX COUNT VALUE 
A 
MAX COUNT VALUE 
B 
MODE/CONTROL 
WORD 


INTERNAL ADDRESS/DATA BUS 


Figure 19. Timer Block Diagram 


Figure 20. Timer Mode/Control Register 
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Since the count registers and the maximum count registers 
are all 16-bits wide, 16 bits of resolution are provided. Any 
Read or Write access to the timers will add one wait state to 
the minimum four-clock bus cycle. However, this is needed to 
synchronize and coordinate the internal data flows between 
the internal timers and the internal bus. 


The timers have several programmable options. 

0 All three timers can be set to halt or continue on a terminal 
count. 

© Timers 0 and 1 can select between internal and external 
clocks, alternate between MAX COUNT registers and be 
set to retrigger on external events. 

© The timers may be programmed to cause an interrupt on 
terminal count. 


These options are selectable via the timer mode/control word. 


Timer Mode/Control Register 


The mode/control register (see Figure 20) allows the user to 
program the specific mode of operation or check the current 
programmed status for any of the three integrated timers. 


Table 15. Timer Control Block format 


Register Offset 
66H 


Mode/Control Word 56H 5EH 
Max Count B 54H 5CH not present 
Max Count A 52H 5AH 62H 
Count Register 50H 58H 60H 






















ALT: 


The ALT bit determines which of two MAX COUNT registers is 
used for count comparison. If ALT = 0, register A for that timer 
is always used, while if ALT = 1, the comparison will alternate 
between register A and register B when each maximum count 
is reached. This alternation allows the user to change one 
MAX COUNT register while the other is being used, and thus 
Provides a method of generating nonrepetitive waveforms. 
Square waves and pulse outputs of any duty cycle are a 
subset of available signals obtained by not changing the final 
count registers. The ALT bit also determines the function of 
the timer output pin. If ALT is zero, the output pin will go LOW 
for one clock, the clock after the maximum count is reached, If 
ALT is one, the output pin will reflect the current MAX COUNT 
register being used (0/1 for B/A). 


CONT: 


Setting the CONT bit causes the associated timer to run 
continuously, while resetting it causes the timer to halt upon 
maximum count. If CONT = 0 and ALT = 1, the timer will count 
to the MAX COUNT register A value, reset, count to the 
register B value, reset, and halt. 


EXT: 


The external bit selects between internal and external clocking 
for the timer. The external signal may be asynchronous with 
respect to the 80188 clock. If this bit is set, the timer will count 
LOW-to-HIGH transitions on the input pin. If cleared, it will 
count an internal clock while using the input pin for control. In 
this mode, the function of the external pin is defined by the 
RTG bit. The maximum input to output transition latency time 
may be as much as 6 clocks. However, clock inputs may be 
pipelined as closely together as every 4 clocks without losing 
clock pulses. 


P: 


The prescaler bit is ignored unless internal clocking has been 
selected (EXT = 0). If the P bit is a zero, the timer will count at 
one-fourth the internal CPU clock rate. If the P bit is a one, the 
output of timer 2 will be used as a clock for the timer. Note that 
the user must initialize and start timer 2 to obtain the prescaled 
clock. 


RTG: 


Retrigger bit is only active for internal clocking (EXT = 0). In 
this case it determines the control function provided by the 
input pin. 


If RTG = 0, the input level gates the internal clock on and off. 
If the input pin is HIGH, the timer will count; if the input pin is 
LOW, the timer will hold its value. As indicated previously, the 
input signal may be asynchronous with respect to the 80188 
clock. 


When RTG = 1, the input pin detects LOW-to-HIGH transi- 
tions. The first such transition starts the timer running, clearing 
-the timer value to zero on the first clock, and then increment- 
ing thereafter. Further transitions on the input pin will again 
reset the timer to zero, from which it will start counting up 
again. If CONT =0, when the timer has reached maximum 
count, the EN bit will be cleared, inhibiting further timer activity. 


EN: 


The enable bit provides programmer control over the timer's 
RUN/HALT status. When set, the timer is enabled to incre- 
ment subject to the input pin constraints in the internal clock 
mode (discussed previously). When cleared, the timer will be 
inhibited from counting. All input pin transitions during the time 
EN is zero will be ignored. If CONT is zero, the EN bit is 
automatically cleared upon maximum count. 











INH: 


The inhibit bit allows for selective updating of the enable (EN) 
bit. If INH is a one during the write to the mode/control word, 
then the state of the EN bit will be modified by the write. If INH 
is a zero during the write, the EN bit will be unaffected by the 
operation. This bit is not stored; it will always be a 0 on a read. 


INT: 


When set, the INT bit enables interrupts from the timer, which 
will be generated on every terminal count. If the timer is 
configured in dual MAX COUNT register mode, an interrupt will 
be generated each time the value in MAX COUNT register A is 
reached, and each time the value in MAX COUNT register B is 
reached. If this enable bit is cleared after the interrupt request 
has been generated, but before a pending interrupt is ser- 
viced, the interrupt request will still be in force. (The request is 
latched in the Interrupt Controller.) 


MC: 


The Maximum Count bit is set whenever the timer reaches its 
final maximum count value. If the timer is configured in dual 
MAX COUNT register mode, this bit will be set each time the 
value in MAX COUNT register A is reached, and each time the 
value in MAX COUNT register B is reached. This bit is set 
regardless of the timer's interrupt-enable bit. The MC bit gives 
the user the ability to monitor timer status through software 
instead of through interrupts. 


RIU: 


The Register In Use bit indicates which MAX COUNT register 
is currently being used for comparison to the timer count 
value. A zero value indicates register A. The RIU bit cannot be 
written, i.e., its value is not affected when the control register 
is written. It is always cleared when the ALT bit is zero. 


Not all mode bits are provided for timer 2. Certain bits 
are hardwired as indicated below: 


ALT = 0, EXT=0, P=0, RTG=0, RIU=0 


Count Registers 


Each of the three timers has a 16-bit count register. The 
current contents of this register may be read or written by the 
processor at any time. If the register is written into while the 
timer is counting, the new value will take effect in the current 
count cycle. 


Max Count Registers 


Timers 0 and 1 have two MAX COUNT registers, while timer 2 
has a single MAX COUNT register. These contain the number 
of events the timer will count. In timers 0 and 1, the MAX 
COUNT register used can alternate between the two max 
count values whenever the current maximum count is 
reached. The condition which causes a timer to reset is 
equivalent between the current count value and the max count 
being used. This means that if the count is changed to be 
above the max count value, or if the max count value is 
changed to be below the current value, the timer will not reset 
to zero, but rather will count to its maximum value, "wrap 
around" to zero, then count until the max count is reached. 


Timers and Reset 


Upon RESET, the Timers will perform the following actions: 

@ All EN (Enable) bits are reset preventing timer counting. 

@ All SEL (Select) bits are reset to zero. This selects MAX 
COUNT register A, resulting in the Timer Out pins going 
HIGH upon RESET. 











INTERRUPT CONTROLLER 


The 80188 can receive interrupts from a number of sources, 
both internal and external. The internal interrupt controller 
serves to merge these requests on a priority basis, for 
individual service by the CPU. Internal interrupt sources 
(Timers and DMA channels) can be disabled by their own 
control registers or by mask bits within the interrupt controller. 
The 80188 interrupt controller has its own control registers 
that set the mode of operation for the controller. 


The interrupt controller will resolve priority among requests 
that are pending simultaneously. Nesting is provided so 
interrupt service routines for lower priority interrupts may 
themselves be interrupted by higher priority interrupts. A block 
diagram of the interrupt controller is shown in Figure 21. 


The interrupt controller has a special iRMX 86 compatibility 
mode that allows the use of the 80188 within the IRMX 86 
operating system interrupt structure. The controller is set in 
this mode by setting bit 14 in the peripheral control block 
relocation register (see iRMX 86 Compatibility Mode section). 
In this mode, the internal 80188 interrupt controller functions 
as a "slave" controller to an external ''master'’ controller. 
Special initialization software must be included to properly set 
up the 80188 interrupt controller in iIRMX 86 mode. 


MASTER (NON-iIRMX) MODE OPERATION 


interrupt Controller External Interface 


For external interrupt sources, five dedicated pins are provid- 
ed. One of these pins is dedicated to NMI, non-maskable 
interrupt. This is typically used for power-fail interrupts, etc. 
The other four pins may function either as four interrupt input 
lines with internally generated interrupt vectors, as an interrupt 
line and an interrupt acknowledge line (called the "cascade 
mode") along with two other input lines with internally generat- 
ed interrupt vectors, or as two interrupt input lines and two 
dedicated interrupt acknowledge ouput lines. When the inter- 
rupt lines are configured in cascade mode, the 80188 interrupt 
controller will not generate internal interrupt vectors. 


External sources in the cascade mode use externally generat- 
ed interrupt vectors. When an interrupt is acknowledged, two 
INTA cycles are initiated and the vector is read into the 80188 
on the second cycle. The capability to interface to external 
8259A programmable interrupt controllers is thus provided 
when the inputs are configured in cascade mode. 


Interrupt Controller Modes of Operation 


The basic modes of operation of the interrupt controller in non- 
iRMX mode are similar to the 8259A. The interrupt controller 
responds identically to internal interrupts in all three modes: 
the difference is only in the interpretation of function of the 
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four external interrupt pins. The interrupt controller is set into 
one of these three modes by programming the correct bits in 
the INTO and INT1 control registers. The modes of interrupt 
controller operation are as follows: 


Fully Nested Mode 


When in the fully nested mode four pins are used as direct 
interrupt requests. The vectors for these four inputs are 
generated internally. An in-service bit is provided for every 
interrupt source. If a lower-priority device requests an interrupt 
while the in-service bit (IS) is set, no interrupt will be generated 
by the interrupt controller. In addition, if another interrupt 
request occurs from the same interrupt source while the 
inservice bit is set, no interrupt will be generated by the 
interrupt controller. This allows interrupt service routines to 
operate with interrupts enabled without being themselves 
interrupted by lower-priority interrupts. Since interrupts are 
enabled, higher-priority interrupts will be serviced. 


When a service routine is completed, the proper IS bit must be 
reset by writing the proper pattern to the EO! register. This is 
required to allow subsequent interrupts from this interrupt 
source and to allow servicing of lower-priority interrupts. An 
EO! command is issued at the end of the service routine just 
before the issuance of the return from interrupt instruction. If 
the fully nested structure has been upheld, the next highest- 
priority source with its IS bit set is then serviced. 


Cascade Mode 


The 80188 has four interrupt pins and two of them have dual 
functions. In the fully nested mode the four pins are used as 
direct interrupt inputs and the corresponding vectors are 
generated internally. In the cascade mode, the four pins are 
configured into interrupt input-dedicated acknowledge signal 
pairs. The interconnection is shown in Figure 22. INTO is an 
interrupt input interfaced to an 8259A, while INT2/INTAO 
serves as the dedicated interrupt acknowledge signal to that 
peripheral. The same is true for INT1 and INT3/INTA1. Each 
pair can selectively be placed in the cascade or non-cascade 
mode by programming the proper value into INTO and INT1 
control registers. The use of the dedicated acknowledge 
signals eliminates the need for the use of external logic to 
generate INTA and device select signals. 


The primary cascade mode allows the capability to serve up to 
128 external interrupt sources through the use of external 
master and slave 8259As. Three levels of priority are created, 
requiring priority resolution in the 80188 interrupt controller, 
the master 8259As, and the slave 8259As. If an external 
interrupt is serviced, one IS bit is set at each of these levels. 
When the interrupt service routine is completed, up to three 
end-of-interrupt commands must be issued by the program- 
mer. 
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Figure 21. Interrupt Controller Block Diagram 


Special Fully Nested Mode 


This mode is entered by setting the SFNM bit in INTO or INT1 
control register. It enables complete nestability with external 
8259A masters. Normally, an interrupt request from an inter- 
rupt source will not be recognized unless the in-service bit for 
that source is reset. If more than one interrupt source is 
connected to an external interrupt controller, all of the 
interrupts will be funneled through the same 80188 interrupt 
request pin. As a result, if the external interrupt controller 
receives a higher-priority interrupt, its interrupt will not be 
recognized by the 80188 controller until the 80188 in-service 
bit is reset. In special fully nested mode, the 80188 interrupt 
controller will allow interrupts from an external pin regardless 
of the state of the in-service bit for an interrupt source in order 
to allow multiple interrupts from a single pin. An in-service bit 
will continue to be set, however, to inhibit interrupts from other 
lower-priority 80188 interrupt sources. 


Special procedures should be followed when resetting IS bits 
at the end of interrupt service routines. Software polling of the 
external master's IS register is required to determine if there is 
more than one bit set. If so, the IS bit in the 80188 remains 
active and the next interrupt service routine is entered. 


Operation in a Polled Environment 


The controller may be used in a polled mode if interrupts are 
undesirable. When polling, the processor disables interrupts 
and then polls the interrupt controller whenever it is conve- 
nient. Polling the interrupt controller is accomplished by 
reading the Poll Word (Figure 9). bit 15 in the poll word 
indicates to the processor that an interrupt of high enough 
priority is requesting service. Reading the Poll Word causes 
the In-Service bit of the highest-priority source to be set. 


It is desirable to be able to read the Poll Word information 
without guaranteeing service of any pending interrupt, i.e., not 
set the indicated in-service bit. The 80188 provides a Poll 
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Status Word in addition to the conventional Poll Word to allow 
this to be done. Poll Word information is duplicated in the Poll 
Status Word, but reading the Poll Status Word does not set 
the associated in-service bit. These words are located in two 
adjacent memory locations in the register file. 


Master (NON-iIRMX) Mode Features 
Programmable Priority 


The user can program the interrupt sources into any of eight 
different priority levels. The programming is done by placing a 
3-bit priority level (0-7) in the control register of each interrupt 
source. (A source with a priority level of 4 has higher priority 
over all priority levels from 5 to 7. Priority registers containing 
values lower than 4 have greater priority.) All interrupt sources 
have preprogrammed default priority levels (see Table 4). 


If two requests with the same programmed priority level are 
pending at once, the priority ordering scheme shown in Table 
4 is used. If the serviced interrupt routine reenables interrupts, 
it allows other requests to be serviced. 


End-of-interrupt Command 


The end-of-interrupt (EO!) command is used by the program- 
mer to reset the In-Service (IS) bit when an interrupt service 
routine is completed. The EOI command is issued by writing 
the proper pattern to the EOI register. There are two types of 
EO! commands, specific and nonspecific. The nonspecific 
command does not specify which IS bit is reset. When issued, 
the interrupt controller automatically resets the IS bit of the 
highest priority source with an active service routine. A specific 
EOI command requires that the programmer send the interrupt 
vector type to the interrupt controller indicating which source's 
IS bit is to be reset. This command is used when the fully 
nested structure has been disturbed or the highest priority IS 
bit that was set does not belong to the service routine in 
progress. 














Trigger Mode 


The four external interrupt pins can be programmed in either 
edge- or level-trigger mode. The control register for each 
external source has a level-trigger mode (LTM) bit. All interrupt 
inputs are active HIGH. In the edge sense mode or the level- 
trigger mode the interrupt request must remain active (HIGH) 
until the interrupt request is acknowledged by the 80188 CPU. 
In the edge-sense mode, if the level remains high after the 
interrupt is acknowledged, the input is disabled and no further 
requests will be generated. The input level must go LOW for at 
least one clock cycle to reenable the input. In the level-trigger 
mode, no such provision is made: holding the interrupt input 
HIGH will cause continuous interrupt requests. 


Interrupt Vectoring 


The 80188 Interrupt Controller will generate interrupt vectors 
for the integrated DMA channels and the integrated Timers. In 
addition, the Interrupt Controller will generate interrupt vectors 
for the external interrupt lines if they are not configured in 
Cascade or Special Fully Nested Mode. The interrupt vectors 
generated are fixed and cannot be changed (see Table 4). 


Interrupt Controller Registers 


The Interrupt Controller register model is shown in Figure 23. It 
contains 15 registers. All registers can both be read or written 
unless specified otherwise. 


In-Service Register 


This register can be read from or written into. The format is 
shown in Figure 24. It contains the In-Service bit for each of 
the interrupt sources. The In-Service bit for each of the 
interrupt sources. The In-Service bit is set to indicate that a 
source's service routine is in progress. When an In-Service bit 
is set, the interrupt controller will not generate interrupts to the 
CPU when it receives interrupt requests from devices with a 





Figure 22. Cascade Mode Interrupt Connection 
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lower programmed priority level. The TMR bit is the In-Service 
bit for all three timers; the DO and D1 bits are the In-Service 
bits for the two DMA channels; the 10-13 are the In-Service 
bits for the external interrupt pins. The IS bit is set when the 
processor acknowledges an interrupt request either by an 
interrupt acknowledge or by reading the poll register. The IS 
bit is reset at the end of the interrupt service routine by an end- 
of-interrupt command issued by the CPU. 


Interrupt Request Register 


The internal interrupt sources have interrupt request bits inside 
the interrupt controller. The format of this register is shown in 
Figure 24. A read from this register yields the status of these 
bits. The TMR bit is the logical OR of all timer interrupt 
requests. DO and D1 are the interrupt request bits for the DMA 
channels. 


The state of the external interrupt input pins is also indicated. 
The state of the external interrupt pins is not a stored condition 
inside the interrupt controller, therefore the external interrupt 
bits cannot be written. The external interrupt request bits show 
exactly when an interrupt request is given to the interrupt 
controller, so if edge-triggered mode is selected, the bit in the 
register will be HIGH only after an inactive-to-active transition. 
For internal interrupt sources, the register bits are set when a 
request arrives and are reset when the processor acknowl- 
edges the requests. 


Mask Register 


This is a 16-bit register that contains a mask bit for each 
interrupt source. The format for this register is shown in Figure 
24. Aone in a bit position corresponding to a particular source 
serves to mask the source from generating interrupts. These 
mask bits are the exact same bits which are used in the 
individual control registers; programming a mask bit using the 
mask register will also change this bit in the individual control 
registers, and vice versa. 


AF002801 










Priority Mask Register 
OFFSET : . : , ; 
SEH This register is used to mask all interrupts below particular 
interrupt priority levels. The format of this register is shown in 
3CH Figure 25. The code in the lower three bits of this register 
inhibits interrupts of priority lower (a higher priority number) 
3AH than the code specified. For example, 100 written into this 
register masks interrupts of level five (101), six (110), and 
38H seven (111). The register is reset to seven (111) upon RESET 
so all interrupts are unmasked. 
= Interrupt Status Register 
34H This register contains general interrupt controller status infor- 
mation. The format of this register is shown in Figure 26. The 
92H bits in the status register have the following functions: 
a DHLT:DMA Halt Transfer; setting this bit halts all DMA 
TER transfers. It is automatically set whenever a non- 
maskable interrupt occurs, and it is reset when an IRET 
instruction is executed. The purpose of this bit is to 
allow prompt service of all non-maskable interrupts. 
This bit may also be set by the CPU. 
IRTx: These three bits represent the individual timer interrupt 
request bits. These bits are used to differentiate the 
timer interrupts, since the timer IR bit in the interrupt 
request register is the "OR" function of all timer 
interrupt requests. Note that setting any one of these 
three bits initiates an interrupt request to the interrupt 


Figure 23. Interrupt Controller Registers 
(Non-iIRMX 86 Mode) 


15 14 “10 9 8 7 6 5 4 3 2 1 0 
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Figure 24. In-Service, Interrupt Request, and Mask Register Formats 


Figure 25. Priority Mask Register Format 


15 14 


7 6 5 4 3 2 1 0 
feurp of. do Po fe Le] o [arp en [iro 


Figure 26. Interrupt Status Register Format 
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Timer, DMA 0, 1; Control Registers 





These registers are the control words for all the internal 
interrupt sources. The format for these registers is shown in 
Figure 27. The three bit positions PRO, PR1, and PR2 
represent the programmable priority level of the interrupt 
source. The MSK bit inhibits interrupt requests from the 
interrupt source. The MSK bits in the individual control 
registers are the exact same bits as are in the Mask Register; 
modifying them in the individual control registers will also 
modify them in the Mask Register, and vice versa. 


INTO-INT3 Control Registers 


These registers are the control words for the four external 
input pins. Figure 28 shows the format of the INTO and INT1 
Control registers; Figure 29 shows the format of the INT2 and 
INT3 Control registers. In cascade mode or special fully 
nested mode, the control words for INT2 and INT3 are not 
used. 


The bits in the various control registers are encoded as 
follows: 


PRO-2: Priority programming information. Highest priori- 
ty = 000, lowest priority = 111. 


LTM: Level-trigger mode bit. 1 = level-triggered; 
0 = edge-triggered. Interrupt Input levels are ac- 
tive high. In level-triggered mode, an interrupt is 
generated whenever the external line is high. 


15 14 


3 2 1 0 
po pop. ff is | pre | rt | Pro | 


Figure 27. Timer/DMA Control Register Formats 


15 14 


6 5 4 3 2 1 0 
po fot. | fen] c [ttm | wsk | pre | pri | Pro | 


Figure 28. INTO/INT1 Control Register Formats 


15 14 












In edge-triggered mode, an interrupt will be 
generated only when this level is preceded by 
an inactive-to-active transition on the line. In 
both cases, the level must remain active until 
the interrupt is acknowledged. 








MSK: Mask bit, 1 = mask; 0 = nonmask. 







Cc: Cascade mode bit, 1 = cascade; 0 = direct 






SFNM: Special fully nested mode bit, 1 = SFNM; 
0 =normal nested mode. 


EOI Register 


The end of the interrupt register is a command register which 
can only be written into. The format of this register is shown in 
Figure 30. It initiates an EO! command when written to by the 
80188 CPU. 


The bits in the EOI register are encoded as follows: 




















Sx: Encoded information that specifies an interrupt 
source vector type as shown in Table 4. For ex- 
ample, to reset the In-Service bit for DMA channel 
0, these bits should be set to 01010, since the 
vector type for DMA channel 0 is 10. Note that to 
reset the single In-Service bit for any of the three 
timers, the vector type for timer 0(8) should be 
written in this register. 















4 
















5 


4 3 2 1 0 
poftof. . | 0 [tt | ask] pre | Prt | PRo | 


Figure 29. INT2/INT3 Control Register Formats 





NSPEC/: A bit that determines the type of EOI command. 
SPEC Nonspecific = 1, Specific = 0. 
Poll and Poll Status Registers 


These registers contain polling information. The format of 
these registers is shown in Figure 31. They can only be read. 
Reading the Poll register constitutes a software poll. This will 
set the IS bit of the highest priority pending interrupt. Reading 
the poll status register will not set the IS bit of the highest 
priority pending interrupt; only the status of pending interrupts 
will be provided. 





Encoding of the Poll and Poll Status register bits are as 
follows: 






Sx: Encoded information that indicates the vector type 
of the highest priority interrupting source. Valid only 
when INTREQ = 1. 













INTREQ: This bit determines if an interrupt request is pres- 
ent. Interrupt Request = 1; no Interrupt Request = 0. 






























iRMX 86 COMPATIBILITY MODE 


This mode allows iRMX 86-80188 compatibility. The interrupt 
model of iRMX 86 requires one master and multiple slave 
8259As in cascaded fashion. When iRMX mode is used, the 
internal 80188 interrupt controller will be used as a slave 
controller to an external master interrupt controller. The 
internal 80188 resources will be monitored through the inter- 
nal interrupt controller, while the external controller functions 
as the system master interrupt controller. 


Upon reset, the 80188 interrupt controller will be in the non- 
iRMX 86 mode of operation. To set the controller in the iRMX 
86 mode, bit 14 of the Relocation Register should be set. 


Because of pin limitations caused by the need to interface to 
an external 8259A master, the internal interrupt controller will 
no longer accept external inputs. There are however, enough 
80188 interrupt controller inputs (internally) to dedicate one to 
each timer. In this mode, each timer interrupt source has its 
own mask bit, IS bit, and control word. 


The iRMX 86 operating system requires peripherals to be 
assigned fixed priority levels. This is incompatible with the 
normal operation of the 80188 interrupt controller. Therefore, 
the initialization software must program the proper priority 


levels for each source. The required priority levels for the 
internal interrupt sources in iRMX mode are shown in Table 
16. 


Table 16. Internal Source Priority Level 


Priority Level Interrupt Source 


Timer 0 
(reserved) 
DMA 0 
DMA 1 
Timer 1 
Timer 2 


These level assignments must remain fixed in the iIRMX 86 
mode of operation. 


iRMX 86 Mode External Interface 


The configuration of the 80188 with respect to an external 
8259A master is shown in Figure 32. The INTO input is used as 
the 80188 CPU interrupt input. INT3 functions as an output to 
send the 80188 slave-interrupt-request to one of the 8 master- 
PIC-inputs. 


15 14 13 5 4 3 2 1 0 
SPEC/ 
RO en oe 


Figure 30. EOI Register Format 


15 14 13 


5 4 3 2 1 0 
INT 


Figure 31. Poll Register Format 


80186 INT. IN 


AODRESS DECODER 


80188 SLAVE INTERRUPT OUTPUT 
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Figure 32. iRMX 86 Interrupt Controller interconnection 











Correct master-slave interface requires decoding of the slave 
addresses (CAS0-2). Slave 8259As do this internally. Be- 
cause of pin limitations, the 80188 salve address will have to 
be decoded externally. INT1 is used as a slave-select input. 
Note that the slave vector address is transferred internally, but 
the READY input must be supplied externally. 


INT2 is used as an acknowledge output, suitable to drive the 
INTA input of an 8259A. 


Interrupt Nesting 


iRMX 86 mode operation allows nesting of interrupt requests. 
When an interrupt is acknowledged, the priority logic masks off 
all priority levels except those with equal or higher priority. 


Vector Generation in the iRMX 86 MODE 


Vector generation in iRMX mode is exactly like that of an 
8259A slave. The interrupt controller generates an 8-bit vector 
which the CPU multiplies by four and uses as an address into a 
vector table. The significant five bits of the vector are user- 
programmable while the lower three bits are generated by the 
priority logic. These bits represent the encoding of the priority 
level requesting service. The significant five bits of the vector 
are programmed by writing to the Interrupt Vector register at 
offset 20H. 


Specific End-of-Interrupt 


In iRMX mode the specific EO| command operates to reset an 
in-service bit of a specific priority. The user supplies a 3-bit 
priority-level value that points to an in-service bit to be reset. 
The command is executed by writing the correct value in the 
Specific EOI register at offset 22H. 


Interrupt Controller Registers in the iRMX 
86 Mode 


All control and command registers are located inside the 
internal peripheral control block. Figure 33 shows the offsets 
of these registers. 


End-of-interrupt Register 


The end-of-interrupt register is a command register which can 
only be written. The format of this register is shown in Figure 
34. It initiates an EOI command when written by the 80188 
CPU. 


The bits in the EOI register are encoded as follows: 


Ly: Encoded value indicating the priority of the 


IS bit to be reset. 
In-Service Register 


This register can be read from or written into. It contains the in- 
service bit for each of the internal sources. The format for this 
register is shown in Figure 35. Bit positions 2 and 3 corre- 
spond to the DMA channels; positions 0, 4, and 5 correspond 
to the integral timers. The source's IS bit is set when the 
processor acknowledges its interrupt request. 


Interrupt Request Register 


This register indicates which internal peripherals have interrupt 
requests pending. The format of this register is shown in 
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Figure 35. The interrupt request bits are set when a request 
arrives from an internal source, and are rest when the 
processor acknowledges the request. 






Mask Register 






This register contains a mask bit for each interrupt source. The 
format for this register is shown in Figure 35. If the bit in this 
register corresponding to a particular interrupt source is set, 
any interrupts from that source will be masked. These mask 
bits are exactly the same bits which are used in the individual 
control registers, i.e., changing the state of a mask bit in this 
register will also change the state of the mask bit in the 
individual interrupt control register corresponding to the bit. 









Control Registers 






These registers are the control words for all the internal 
interrupt sources. The format of these registers is shown in 
Figure 36. Each of the timers and both of the DMA channels 
have their own Control Register. 








The bits of the Control Registers are encoded as follows: 






Pry: 3-bit encoded field indicating a priority level for the 
source; note that each source must be programmed 
at specified levels. 






msk: mask bit for the priority level indicated by pry bits. 



























LEVEL 5 CONTROL REGISTER 
(TIMER 2) 


LEVEL 4 CONTROL REGISTER 
(TIMER 1) 


LEVEL 3 CONTROL REGISTER 
(DMA 1) 


LEVEL 2 CONTROL REGISTER 
(DMA 0) 


LEVEL 0 CONTROL REGISTER 
(TIMER 0) 





























INTERRUPT-REQUEST REGISTER 


















IN-SERVICE REGISTER 












PRIORITY-LEVEL MASK REGISTER 










MASK REGISTER 
















SPECIFIC EOI REGISTER 











INTERRUPT VECTOR REGISTER 





Figure 33. Interrupt Controller Registers 
(iRMX 86 Mode) 
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Figure 34. Specific EQI Register Format 
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Figure 35. In-Service, Interrupt Request, and Mask Register Format 


Interrupt Vector Register 


This register provides the upper five bits of the interrupt vector 
address. The format of this register is shown in Figure 37. The 
interrupt controller itself provides the lower three bits of the 
interrupt vector as determined by the priority level of the 
interrupt request. 


The format of the bits in this register is: 


tx: 5-bit field indicating the upper five bits of the vector 
address. 


Priority-Level Mask Register 


This register indicates the lowest priority-level interrupt which 
will be serviced. 


The encoding of the bits in this register is: 


m,: 93-bit encoded field indication priority-level value. All 
levels of lower priority will be masked. 


Interrupt Controller and Reset 


Upon RESET, the interrupt controller will perform the following 
actions: 
@ All SFNM bits reset to 0, implying Fully Nested Mode. 
© All PR bits in the various control registers set to 1. Tis 
places all sources at lowest priority (level 111). 
All LTM bits reset to 0, resulting in edge-sense mode. 
All Interrupt Service. bits reset to 0. 
All Interrupt Request bits reset to 0. 
All MSK (Interrupt Mask) bits set to 1 (mask). 
All C (Cascade) bits reset to 0 (non-cascade). 
All PRM (Priority Mask) bits set to 1, implying no levels 
masked. 
Initialized to NON-iRMX 86 mode. 
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Figure 36. Control Word Format 
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Figure 37. Interrupt Vector Register Format 
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Figure 38. Priority Level Mask Register 
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ADDRESS 


80188-10 


tcs 


TMR INO 
TMR OUT 0 


TERMINAL 


INTERFACE K|___ > () DISK 


HARDWARE 


AF002826 


Figure 39. Typical 80188 Computer 
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BUS CONTROL 
COMMANDS 


CLK 


BUS 
ARBITER eet 
SYSS/RESB ATION 


AF002835 


Figure 40. Typical 80188 Multi-Master Bus Interface 
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ABSOLUTE MAXIMUM RATINGS OPERATING RANGES 


Storage Temperature -65°C to +150°C Commercial (C) Devices 

Voltage on Any Pin with Temperature (Ta) 
Respect to Ground -10Vto +7 V (Tc).... 

Power Dissipation (steady state 70°C)................... 2.0 W Supply Voltage (Vcc) 


Industrial (I) Devices 
Temperature (Ta) 
Supply Voltage (Vcc) . 


Stresses above those listed under ABSOLUTE MAXIMUM 
RATINGS may cause permanent device failure. Functionality 
at or above these limits is not implied. Exposure to absolute 
maximum ratings for extended periods may affect device Operating ranges define those limits between which the 
reliability. functionality of the device is guaranteed. 


DC CHARACTERISTICS (over operating range unless otherwise specified) 


input LOW Voltage EL 
Input HIGH Voltage 
input HIGH Voltage (RES) S80 V0 vis —_—| 
Ia = 2.5 mA for SO-S2 
Output LOW Voltage la = 2.0 mA for all other outputs se 


Output HIGH Voltage loa =—400 HA 


Power Supply Current 
Cin 
Cio 


0. V< Viv =Voo 
in= 40 mA 
[on [put Gapactencs = 
[GoW Capacitance | 2 


SWITCHING CHARACTERISTICS 
PIN TIMING 
80188 Timing Requirements All Timings Measured At 1.5 Volts Unless Otherwise Noted 


80188-10 (10 MHz)| 80188 (8 MHz) 


[Parameters | Description | Test Conditions | win] Max. | Min, | Max | Units | 

2 YN 

[Tox | Oatain od WO) SST SSCS ~~ d| STC Sts 

BN 
(AREADY) active setup time 

[ Tanvict | AREADY inactive soup time | _———S~CSCSCS~Sr S| SSSC*dY SCT SCC 

[ Tonanvx | AREADY hold time | SSSCSC~SYS' CYT CC*d 


TARYCHL Asynchronous Ready inactive hold 15 
time 
TSRYCL Synchronous Ready 
(SREADY) transition setup time 
SREADY tension hold ime [| 
HOLD Setup ee 
INTR, NM, TEST, TIMERIN Soup” [| 
DRQO, OAGH, Setup ee 


"To guarantee recognition at next clock. 
For Industrial Grade Parts only. 



















SWITCHING CHARACTERISTICS (Cont'd.) 
80188 Master Interface Timing Responses 















Parameters Description Test Conditions | min. | Max. | min. | Max. | 

PTouay __[Adaress valid Dey ———=S=*dL = 20-200 pra outs | 5 | 4 | 5 | 8 | ms 
PTouax [Address Ho TTT 
Toaz [Address Float Delay] Yea | | TOA | 35 [re | 
FToncz [Command tines Float Delay [| | | | 
TCHCV Command Lines Valid Delay 45 

Re Neem Se ie ee eae 
TT «ALE Win CidTSC TTCSC™~C—CS Truc (|| ec [ns 
Frown [ALE Active Day | SCOC™~—CS SSCCd CT | 
[Ton [ALE Inactive Delay | Ys 
PTuax [Address Hold to ALE Inactve | ——SSSCSC~<C~*~*~‘“~*~*~*wCL ~~ CCTCHCLS || 
[Toy [Data vad Dewy TT Tt ae 
[Touox__—([DataHold Time | tts 
PTwaox [Data Hod after WAT SCSC~C~“~*~*~dC «CO [ns 
FTovery _|Gontrol Active Delays STS CSCSC~<“‘;C~‘dT SC TCT | CCT SO Cos 
FToncry [Control Active Dely2 S| CCT SCT TTT 
Tovorx [Control inactive Delay | | | LL || 
TCVDEX DEN Inactive Delay 10 10 70 

ORE el nantee Se ne ae Vine ee al el 
[TazeL___—*|Address Floatto RD Actve = [| Ts 
[Tount___—«([AD Active Delay | CT te Pts 
[Tounh [AD Inactive Delay | Ett ts 
Tanay [AO Inactive to Adsross Acie | —SSSSCSC*sYCTWO || TO [|r 
PToumay [HUDBA Valid Delay | CT | TL Os 
Piru [Rowan CdTSSCSC~—“—~S*~s~S~S*SCSC~S CTCL |S acc | [ne 
Piwwa  |WRwem dT CSC™~CSCSCSC~S CTCL | acc [rs 
Tava [Address Valid to ALELOW | SSCSC~dCTLM || TUS | 
[Tcusv _—‘[Status Active Delay | Tt tT | 
Fos [Status inactive Dey | CT dT Tt Te 
[Tourmy [Timer Output Delay Sid SSO mex || || Os 
FTouno_[ResstOowy CdS TTTCC™~—CsCSTSSSC<C~C~dCSC( a] Cd Cs 
FTonasy [Queue StausDoay SS] SS TCCCSCSCSC~—~iTSSCSCSC~d TCT 
FTouox [Stas Hod Time | TTC SCOTT CTs | 
TTavon [Address Valid to Glock HIGH | CST SCT SCT Tos 
LOOK Valid/invalid Delay a eel te | 























80188 Chip-Select Timing Responses 


Description 


To.osv Ghip-Selent Aris Vey el 
Chip-Select Hold from 
Toxcsx Command Inactive 


TcHcsx GChip-Select Inactive Delay 
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SWITCHING CHARACTERISTICS (Cont'd.) 
80188 CLKIN Requirements 


80188-10 (10 MHz) 80188 (8 MHz) 
Parameters Description Test Conditions | min. | | min. | 


[eas | 250 | me | 
aa Oe 
[Town | CLKIN Riso Time ——~—S*dt Aw 9S vows sd ~SSSSSC*dT St | SSC*dY | 
[Toux | KIN LOW Time «dt 1S volts SSSSSCSCiY S| ST Td 
Tose | GLKIN- HIGH Time [15 vows] 20] | #5 | | | 


80188 CLKOUT Timing (200 pF load) 


[Parameters] Description | Test Gonaitions [win | Wax [win | Max [Unite | 
Toco | CK w cLKOUT Sew <P SSCSC~—~—SCSCS SSCSCSCSCSir CdCl | 
To, | GLKOUT Porg SSP SSCS 0800 | ves 50a 
Toon | CLKOUT LOW Time ‘(| tS vets ——SSC~dC | Cd TS | | 
Too. | CLKOUT HIGH Time Piswts Si aTeua80 | | eta | |e 
Tonic | CLKOUT Rise Tme | 19w9svons——~+| ST |) Ss 
Toizouy | OLKOUT Fall Time] 85101 vots | | @ |_| 18 | 1s 


All timings measured at 1.5 volts unless otherwise noted. 


FToan | KW Period Sid SSCS «dC 
[10 | 


SWITCHING TEST INPUT/OUTPUT WAVEFORM 


: 1.5 =— TEST POINTS —= 1.5 


AC testing inputs are driven at 2.4 V for a logic ''1'' and 0.45 V for a logic ''0."" The clock is driven at 
4.3 V and 0.25 V. Timing measurements are made at 1.5 V for both a logic '1'' and "0." 


WF001870 
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SWITCHING WAVEFORMS 
MAJOR CYCLE TIMING 


Vou Tt a Ts 7 
<e-— TCLCL reac ,/ 


EE 


XY | | | L7/ tll as 


TCHCZ 


TCLAV —>| 
=! NOTE 1 


: ae 
ns 
Aig/Se~Arg/Sy eee 
Ais~As —————_ Aqg-Ag (FLOAT DURING INTA) 


an 


TCLAZ 


TCHLH > 
meee 


TCLAV —> 


WRITE CYCLE NOTE 1 
TF a 
RD. INTA, 
ss \ an 


| 
}<— TCLOX 


AD,-ADy 
POINTER 


ADj-AD, Meek) FLOAT 
| 3a 
Te te ry 


RO, WR, - Von 
ers 


INVALID ADDRESS 


— 
TCHCSX —> 


TCXCSX —> 


WF006214 
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SWITCHING WAVEFORMS (Cont'd.) 
MAJOR CYCLE TIMING (Cont'd.) 


Tt Te Ts Tw an 
TCLCL TCHICHZ 
Ven TCHICH2 


CLK OUT y 
Vou bared 


5.55 ie cml 
TCHDX 


ITCLAX 


ee ie Gp Came 
TCHLH He i: 

in 

=e 


FLOAT 
( _ aTAIN] mY 


READ CYCLE TeLAN 
, cers i 


P 
‘| 


TCHCSX 


AD,-AD, 


TCHCTV 


<t—TCLCSV TCXCSX 7 =< 


WF006225 


Notes: 

1. Following a Write cycle, the Local Bus is floated by the 80188 only when the 
80188 enters a "Hold Acknowledge"’ state. 

2. INTA occurs one clock later in RMX-mode. 

3. Status inactive just prior to T4. 
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SWITCHING WAVEFORMS (Cont'd.) 


WF006232 


WF006240 


CLKOUT 


TCHQSV 


WF006250 
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EN 


A19/S6-A16/S3, 
RD, WR, 

S7, 

ov/R, 

§2-S0 


80188 


SWITCHING WAVEFORMS (Cont'd.) 
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HOLD-HLDA TIMING 
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ee 
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}-- 


SiN 


A 


TCHCV 


TARYLCL—>| <— 


WF006262 


WF006270 


ie TCLAV 


80188 


WF006282 





SWITCHING WAVEFORMS (Cont'd.) 


TCKIN 


TCKLH 


TCH1ICH2 


CLKOUT 


TCLCK 


<+— TCL2CL1 


WF006293 


TIMER ON 80188 


TINVCH 


TIMERIN 


TIMEROUT 


80188 INSTRUCTION TIMINGS 


The following instruction timings represent the minimum 
execution time in clock cycles for each instruction. The timings 
given are based on the following assumptions:, 

@ The opcode, along with any data or displacement required 
for execution of a particular instruction, has been pre- 
fetched and resides in the queue at the time it is needed. 

@ No wait states or bus HOLDS occur. 
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WF006300 


e@ All word-data is located on even-address boundaries. 


All jumps and calls include the time required to fetch the 
opcode of the next instruction at the destination address. 


All instructions which involve memory reference can require 
one (and in some cases, two) additional clocks above the 
minimum timings shown. This is due to the asynchronous 
nature of the handshake between the BIU and the Execution 
unit. 








FUNCTION 


DATA TRANSFER 
MOV = Move: 


Register to Register/Memory 
Register/memory to register 
Immediate to register/memory 
Immediate to register 

Memory to accumulator 
Accumulator to memory 
Register/memory to segment register 
Segment register to register/memory 


PUSH = Push: 
Memory 


Register 


Segment register 


Register 


Segment register 


2 change: ss 
Register/memory with register 
Register with accumulator 


IN = Input from: 
Fixed port 


Variable port 


OUT = Output to: 
Fixed port 


Variable port 

XLAT = Translate byte to AL 
LEA = Load EA to register 
LDS = Load pointer to DS 
LES = Load pointer to ES 
LAHF = Load AH with flags 
SAHF = Store AH into flags 
PUSHF = Push flags 

POPF = Pop flags 


INSTRUCTION SET SUMMARY 


FORMAT 


1000100w mod reg r/m 


1000101w mod reg r/m 


mod 000 f/m 
1011w reg 
1010000w addr-low 


1010001w addr-low 


10001110] modOreg r/m 
10001100 


mod 0 reg r/m 


11111111 mod 110 r/m 
01010 reg 


000reg110 
011010s1 


data if w=1 
addr-high 
addr-high 


data if s=0 


01100000) 


10001111 mod 0 0 0 r/m 


01011 reg 


01100001 


1000011Ww mod reg r/m 


10010 reg 


1110010w 


1110111w 
11010111 


10001101 mod reg r/m 


11000101 mod reg r/m 
11000100 mod reg r/m 
10011111 
10011110 
10011100 


10011101 


000reg111 (reg #01) 


(mod # 11) 
(mod # 11) 


Shaded areas indicate new 80188 instructions not available in 8086 or 8088 microprocessors. 


All mnemonics copyright of Intel Corp. 1982 


41 


8/16-bit 
8/16-bit 





INSTRUCTION SET SUMMARY (Cont'd.) 


Clock 
FUNCTION FORMAT Cycles Comments 


ARITHMETIC 
ADD = Add: 


Reg/memory with register to either 000000dw mod reg r/m 


mod 0 0 0 r/m data data if s w=01 


Immediate to register / memory 100000sw 


Immediate to accumulator 0000010w data data if w=1 8/16-bit 


ADC = Add with carry: 
Reg/memory with register to either 000100dw mod reg r/m 


mod 0 10 r/m data if s w=01 


Immediate to register/memory 100000sw 


Immediate to accumulator 0001010w data data if w=1 8/16-bit 


INC = Increment: 


Register/memory 11111114w{ mod000r/m 


Register 01000 reg 
SUB = Subtract: 
Reg/memory and register to either 001010dw 


mod reg r/m 


mod 10 1 r/m data if s w=01 


Immediate from accumulator 0010110w data data ifw=1 
SBB = Subtract with borrow: 


Immediate from register/memory 100000sw 


8/16-bit 


Reg/memory and register to either 000110dw mod reg r/m 


Immediate from register/memory 100000sw mod 0 1 1 r/m data if s w=01 


Immediate from accumulator 0001110w data if w=1 8/16-bit 


DEC = Decrement: 
Register/memory 11111114WwWJ mod001r/m 
Register -01001 reg 

CMP = Compare: 


Register/memory with register 0011101WwW mod reg r/m 


Register with register/memory 0011100w mod reg r/m 


Immediate with register/memory 100000sw mod 111 r/m 


data if s w=01 


Immediate with accumulator 0011110w data data if w=1 


NEG = Change sign 11110114w] mod0111r/m 
AAA=ASCIl adjust for add 
DAA = Decimal adjust for add 00100111 
AAS = ASCII adjust for subtract 00111111 


DAS = Decimal adjust for subtract 00101111 


MUL = Mulitiply (unsigned) 


Register-Byte 
Register-Word 
Memory-Byte 
Memory-Word 


IMUL = Integer multiply (signed): 


Register-Byte 
Register-Word 
Memory-Byte 


mod 1 0 0 r/m 


mod 1 0 1 r/m 


DIV = Divide (unsigned): [11110114w| mod110r/m 


Register-Byte 
Register-Word 
Memory-Byte 
Memory-Word 


Shaded areas indicate new 80188 instructions not available in 8086 or 8088 microprocessors. 


All mnemonics copyright of Intel Corp. 1982 
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INSTRUCTION SET SUMMARY (Cont'd.) 


FUNCTION FORMAT 


ARITHMETIC (Continued): 


IDIV = Integer divide (signed): mod 111 ¢/m 


Register-Byte 
Register-Word 
Memory-Byte 
Memory-Word 


AAM = ASCII adjust for multiply 11010100;]00001010 


AAD = ASCII adjust for divide 00001010 
CBW = Convert byte to word 10011000 
CWD = Convert word to double word 10011001 


LOGIC 
Shift/Rotate Instructions: 


Register/Memory by 1 1101000w mod TTT r/m 2/15 
mod TTT r/m 
mod TTT r/m 


Register/Memory by CL 1101001Ww 


Memory by Count 


1100000w 


count S+n/17+n 


Instruction 
ROL 
ROR 
RCL 
RCR 

SHL/SAL 
SHR 
SAR 


4 


a3 30000 
-O0O+-+00 
432032030 


AND = And: 
Reg/memory and register to either 001000dw mod reg r/m 


Immediate to register/memory 1000000wW| mod100r/m 


Immediate to accumulator 0010010w data data if w=1 8/16-bit 


TEST = And function to flags, no result: 
Register/memory and register 1000010w mod reg r/m 
Immediate data and register/memory 1111011W| mod000r/m data data if w=1 


Immediate data and accumulator 1010100w data if w=1 8/16-bit 


OR = Or: 
Reg/memory and register to either 000010dw mod reg r/m 


Immediate to register/memory 1000000w mod 0 0 1 r/m data data if w=1 


Immediate to accumulator 0000110w data data if w=1 8/16-bit 


XOR = Exclusive or: 
Reg/memory and register to either 001100dw mod reg r/m 


Immediate to register/memory 1000000w mod 110 r/m data if w=1 


8/16-bit 


Immediate to accumulator 0011010w 
NOT = Invert register/memory 11110114w| mod010r/m 
STRING MANIPULATION: 
MOVS = Move byte/word 1010010w 
CMPS = Compare byte/word 
SCAS = Scan byte/word 

LODS = Load byte/wd to AL/AX 1010110w 


itor byte/wd from AL/A 1010101Ww 


0110110w 


t  fottottiw] 


Shaded areas indicate new 80188 instructions not available in 8086 or 8088 microprocessors. 


All mnemonics copyright of Intel Corp. 1982 
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FUNCTION 


STRING MANIPULATION (Continued): 


Repeated by count in CX 
MOVS = Move string 


CMPS = Compare string 
SCAS = Scan string 
LODS = Load string 
STOS = Store strin: 


CONTROL TRANSFER 
CALL = Call: 


Direct within segment 


Register memory 
indirect within segment 


Direct intersegment 


Indirect intersegment 
JMP = Unconditional jump: 


Short/long 


Direct within segment 


Register/memory indirect within segment 


Direct intersegment 


Indirect intersegment 

RET = Return from CALL: 
Within segment 

Within seg adding immed to SP 
Intersegment 


Intersegment adding immediate to SP 


INSTRUCTION SET SUMMARY (Cont'd.) 


FORMAT 


11110010);1010010w 


1111001z 


1111001z/1010111Ww 


11110010/1010110w 


11110010/1010101Ww 


11101000 disp-high 


1141111141 


mod 0 1 0 r/m 


10011010 segment offset 


segment selector 


11111111 mod 0 1 1 r/m (mod #11) 


11101011 


11101001 
mod 1 0 0 r/m 
11101010 segment offset 


segment selector 


1141111141 mod 1 0 1 r/m (mod # 11) 


11000011 


11000010 data-low data-high 


11001011 
11001010 


data-low data-high 


Shaded areas indicate new 80188 instructions not available in 8086 or 8088 microprocessors. 


All mnemonics copyright of Intel Corp. 1982 
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INSTRUCTION SET SUMMARY (Cont'd.) 


FUNCTION FORMAT 
CONTROL TRANSFER (Continued): 


13 if JMP 
taken 
JL/JNGE = Jump on less not greater or equal 01111100 4 if UMP 
not taken 


JE/JZ = Jump on equal zero 01110100 


JLE/JNG = Jump on less or equal not greater 


JB/JNAE = Jump on below not above or equal 01110010 


JBE/JNA = Jump on below or equal not above 01110110 
JP/JPE = Jump on parity parity even 01111010 


JO = Jump on overflow 01110000 
JS = Jump on sign 01111000 


JNE/JNZ = Jump on not equal not zero 01110101 


JNL/JGE = Jump on not less greater or equal 01111101 


JNLE/JG = Jump on not less or equal greater 


JNB/JAE = Jump on not below above or equal 01110011 


JNBE/JA = Jump on not below or equal above 01110111 
JNP/JPO = Jump on not par / par odd 01111041 
JNO = Jump on not overflow 01110001 


JNS = Jump on not sign 


LOOP = Loop CX times 11100010 


LOOPZ/LOOPE = Loop while zero equal 11100001 
LOOPNZ/LOOPNE = Loop while not zero equal 11100000 


JMP taken/ 
AMP. not 


Jump on CX zero 11100011 


11001000 datalow . | __data-high 


15 
25 
22+ 16(n-1) 


8 
Interrupt: sasiasinah 


Type specified 11001101 


Type 3 11001100 if INT. taken/ 


INTO = Interrupt on overflow if INT. not 
taken 


IRET = Interrupt return 11001111 


value out of range 01100010]. modregr/m | 


Shaded areas indicate new 80188 instructions not available in 8086 or 8088 microprocessors. 


All mnemonics copyright of Intel Corp. 1982 
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INSTRUCTION SET SUMMARY (Cont'd.) 


FUNCTION FORMAT 


PROCESSOR CONTROL 
CLC = Clear carry 11111000 
CMC = Complement carry 11110101 
STC = Set carry 11111001 
CLD = Clear direction 11111100 
STD = Set direction 11111101 
CLI = Clear interrupt 11111010 
STI = Set interrupt 11111011 
HLT = Halt 


WAIT = Wait 10011011 


LOCK = Bus lock prefix 11110000 


ESC = Processor Extension Escape 10011TTT 


FOOTNOTES 
The effective Address (EA) of the memory operand is 
computed according to the mod and r/m fields: 


if mod=11 then r/m is treated as a REG field 

if mod =00 then DISP =0 , disp-low and disp-high are 
absent . 

if mod = 01 then DISP = disp-low sign-extended to 16-bits, 
disp-high is absent 

if mod = 10 then DISP = disp-high: disp-low 


if r/m = 000 then EA = (BX) + (SI) + DISP 
if r/m=001 then EA = (BX) + (Dl) + DISP 
if r/m=010 then EA = (BP) + (SI) + DISP 
if r/m=011 then EA = (BP) + (Dl) + DISP 
if r/m = 100 then EA = (Sl) + DISP 

if r/m=101 then EA = (Dl) + DISP | 

if r/m=110 then EA = (BP) + DISP 

if r/m=111 then EA = (BX) + DISP 


DISP follows 2nd byte of instruction (before data if required) 


“except if mod =00 and r/m=110 then EA = disp-high: disp-low. 
SEGMENT OVERRIDE PREFIX 


001reg i190 


reg is assigned according to the following: 


Segment 
Register 


ES 
cs 
ss 
DS 


mod LLL r/m 


(TTT LLL are opcode to processor extension) 
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Ee 
REG is assigned according to the following table: 


16-Bit (w= 1) 8-Bit (w= 0) 


000 AX 000 AL 
001 Cx 001 CL 
010 Dx 010 DL 
011 BX 011 BL 
100 SP 100 AH 
101 BP 101 CH 
110 SI 110 DH 
111 DI 111 BH 


The physical addresses of all operands addressed by the BP 
register are computed using the SS segment register. The 
physical addresses of the destination operands of the string 
primitive operations (those addressed bythe DI register) are 
computed using the ES segment, which may not be overrid- 
den. 
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PHYSICAL DIMENSIONS (Cont'd.) 
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